home *** CD-ROM | disk | FTP | other *** search
MacBinary | 1994-03-25 | 25.8 KB | [TEXT/ROSA] |
open in:
MacOS 8.1
|
Win98
|
DOS
browse contents |
view JSON data
|
view as text
This file was processed as: MacBinary
(archive/macBinary).
Confidence | Program | Detection | Match Type | Support
|
---|
10%
| dexvert
| MacBinary (archive/macBinary)
| fallback
| Supported |
1%
| dexvert
| Text File (text/txt)
| fallback
| Supported |
100%
| file
| MacBinary II, inited, Fri Mar 25 00:54:09 1994, modified Fri Mar 25 00:54:09 1994, creator 'ROSA', type ASCII, 25718 bytes "assembler.lisp" , at 0x64f6 428 bytes resource
| default (weak)
| |
99%
| file
| data
| default
| |
74%
| TrID
| Macintosh plain text (MacBinary)
| default
| |
25%
| TrID
| MacBinary 2
| default (weak)
| |
100%
| siegfried
| fmt/1762 MacBinary (II)
| default
| |
100%
| lsar
| MacBinary
| default
|
|
id metadata |
---|
key | value |
---|
macFileType | [TEXT] |
macFileCreator | [ROSA] |
hex view+--------+-------------------------+-------------------------+--------+--------+
|00000000| 00 0e 61 73 73 65 6d 62 | 6c 65 72 2e 6c 69 73 70 |..assemb|ler.lisp|
|00000010| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000020| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000030| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000040| 00 54 45 58 54 52 4f 53 | 41 01 00 00 00 00 00 00 |.TEXTROS|A.......|
|00000050| 00 00 00 00 00 64 76 00 | 00 01 ac a9 b8 2d 01 a9 |.....dv.|.....-..|
|00000060| b8 2d 01 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |.-......|........|
|00000070| 00 00 00 00 00 00 00 00 | 00 00 81 81 ad 61 00 00 |........|.....a..|
|00000080| 3b 3b 3b 0d 3b 3b 3b 09 | 09 43 6f 70 79 72 69 67 |;;;.;;;.|.Copyrig|
|00000090| 68 74 20 a9 20 31 39 39 | 34 20 52 6f 67 65 72 20 |ht . 199|4 Roger |
|000000a0| 43 6f 72 6d 61 6e 2e 20 | 20 41 6c 6c 20 72 69 67 |Corman. | All rig|
|000000b0| 68 74 73 20 72 65 73 65 | 72 76 65 64 2e 0d 3b 3b |hts rese|rved..;;|
|000000c0| 3b 0d 0d 3b 0d 3b 09 53 | 6f 75 72 63 65 20 63 6f |;..;.;.S|ource co|
|000000d0| 64 65 20 66 6f 72 20 61 | 73 73 65 6d 62 6c 65 72 |de for a|ssembler|
|000000e0| 2e 0d 3b 0d 0d 3b 0d 3b | 09 57 65 20 64 6f 20 61 |..;..;.;|.We do a|
|000000f0| 6e 20 65 76 61 6c 2d 77 | 68 65 6e 20 6f 6e 20 74 |n eval-w|hen on t|
|00000100| 68 65 20 65 6e 74 69 72 | 65 20 66 69 6c 65 20 73 |he entir|e file s|
|00000110| 6f 20 74 68 61 74 20 77 | 65 20 67 65 74 20 74 68 |o that w|e get th|
|00000120| 65 0d 3b 09 70 65 72 66 | 6f 72 6d 61 6e 63 65 20 |e.;.perf|ormance |
|00000130| 62 65 6e 65 66 69 74 73 | 20 69 6d 6d 65 64 69 61 |benefits| immedia|
|00000140| 74 65 6c 79 0d 3b 0d 28 | 65 76 61 6c 2d 77 68 65 |tely.;.(|eval-whe|
|00000150| 6e 20 28 3a 63 6f 6d 70 | 69 6c 65 2d 74 6f 70 6c |n (:comp|ile-topl|
|00000160| 65 76 65 6c 20 3a 6c 6f | 61 64 2d 74 6f 70 6c 65 |evel :lo|ad-tople|
|00000170| 76 65 6c 20 3a 65 78 65 | 63 75 74 65 29 0d 09 28 |vel :exe|cute)..(|
|00000180| 70 72 6f 76 69 64 65 20 | 3a 61 73 73 65 6d 62 6c |provide |:assembl|
|00000190| 65 72 29 0d 09 28 69 6e | 2d 70 61 63 6b 61 67 65 |er)..(in|-package|
|000001a0| 20 3a 61 73 73 65 6d 62 | 6c 65 72 29 29 0d 0d 28 | :assemb|ler))..(|
|000001b0| 65 76 61 6c 2d 77 68 65 | 6e 20 28 3a 63 6f 6d 70 |eval-whe|n (:comp|
|000001c0| 69 6c 65 2d 74 6f 70 6c | 65 76 65 6c 20 3a 6c 6f |ile-topl|evel :lo|
|000001d0| 61 64 2d 74 6f 70 6c 65 | 76 65 6c 20 3a 65 78 65 |ad-tople|vel :exe|
|000001e0| 63 75 74 65 29 0d 28 65 | 78 70 6f 72 74 20 0d 27 |cute).(e|xport .'|
|000001f0| 28 0d 09 20 61 30 20 20 | 61 31 20 20 61 32 20 20 |(.. a0 |a1 a2 |
|00000200| 61 33 20 20 61 34 20 20 | 61 35 20 20 61 36 20 20 |a3 a4 |a5 a6 |
|00000210| 61 37 0d 20 20 20 20 2d | 61 30 20 2d 61 31 20 2d |a7. -|a0 -a1 -|
|00000220| 61 32 20 2d 61 33 20 2d | 61 34 20 2d 61 35 20 2d |a2 -a3 -|a4 -a5 -|
|00000230| 61 36 20 2d 61 37 0d 09 | 20 61 30 2b 20 61 31 2b |a6 -a7..| a0+ a1+|
|00000240| 20 61 32 2b 20 61 33 2b | 20 61 34 2b 20 61 35 2b | a2+ a3+| a4+ a5+|
|00000250| 20 61 36 2b 20 61 37 2b | 0d 09 20 64 30 20 20 64 | a6+ a7+|.. d0 d|
|00000260| 31 20 20 64 32 20 20 64 | 33 20 20 64 34 20 20 64 |1 d2 d|3 d4 d|
|00000270| 35 20 20 64 36 20 20 64 | 37 0d 09 64 2d 72 65 67 |5 d6 d|7..d-reg|
|00000280| 69 73 74 65 72 73 0d 09 | 61 2d 72 65 67 69 73 74 |isters..|a-regist|
|00000290| 65 72 73 0d 09 61 2d 69 | 6e 63 2d 72 65 67 69 73 |ers..a-i|nc-regis|
|000002a0| 74 65 72 73 0d 09 61 2d | 64 65 63 2d 72 65 67 69 |ters..a-|dec-regi|
|000002b0| 73 74 65 72 73 0d 09 24 | 43 41 52 0d 09 24 43 44 |sters..$|CAR..$CD|
|000002c0| 52 0d 09 24 53 45 54 43 | 41 52 0d 09 24 53 45 54 |R..$SETC|AR..$SET|
|000002d0| 43 44 52 0d 09 24 53 59 | 4d 42 4f 4c 2d 56 41 4c |CDR..$SY|MBOL-VAL|
|000002e0| 55 45 0d 09 24 53 59 4d | 42 4f 4c 2d 50 4c 49 53 |UE..$SYM|BOL-PLIS|
|000002f0| 54 0d 09 24 4e 4f 44 45 | 2d 54 59 50 45 0d 09 24 |T..$NODE|-TYPE..$|
|00000300| 43 4f 4e 53 50 0d 09 24 | 49 4e 54 45 47 45 52 0d |CONSP..$|INTEGER.|
|00000310| 09 24 52 45 54 55 52 4e | 0d 09 24 46 55 4e 43 2d |.$RETURN|..$FUNC-|
|00000320| 42 45 47 49 4e 0d 09 24 | 49 46 0d 09 24 49 46 45 |BEGIN..$|IF..$IFE|
|00000330| 4c 53 45 0d 09 24 52 45 | 46 45 52 45 4e 43 45 0d |LSE..$RE|FERENCE.|
|00000340| 09 6c 69 6e 6b 0d 09 75 | 6e 6c 6b 0d 09 72 74 73 |.link..u|nlk..rts|
|00000350| 0d 09 64 63 2e 77 0d 09 | 64 63 2e 6c 0d 09 6d 6f |..dc.w..|dc.l..mo|
|00000360| 76 65 71 0d 09 6d 6f 76 | 65 2e 6c 0d 09 6d 6f 76 |veq..mov|e.l..mov|
|00000370| 65 2e 62 0d 09 6d 6f 76 | 65 2e 77 0d 09 6d 6f 76 |e.b..mov|e.w..mov|
|00000380| 65 61 2e 6c 0d 09 61 64 | 64 2e 6c 0d 09 61 64 64 |ea.l..ad|d.l..add|
|00000390| 69 2e 6c 0d 09 61 6e 64 | 2e 6c 0d 09 61 6e 64 69 |i.l..and|.l..andi|
|000003a0| 2e 6c 0d 09 6f 72 2e 6c | 0d 09 6f 72 69 2e 6c 0d |.l..or.l|..ori.l.|
|000003b0| 09 65 6f 72 2e 6c 0d 09 | 65 6f 72 69 2e 6c 0d 09 |.eor.l..|eori.l..|
|000003c0| 73 75 62 2e 6c 0d 09 63 | 6d 70 2e 6c 0d 09 74 73 |sub.l..c|mp.l..ts|
|000003d0| 74 2e 6c 0d 09 73 75 62 | 69 2e 6c 0d 09 63 6c 72 |t.l..sub|i.l..clr|
|000003e0| 2e 6c 0d 09 6c 65 61 0d | 09 6a 73 72 0d 09 62 72 |.l..lea.|.jsr..br|
|000003f0| 61 0d 09 62 73 72 0d 09 | 62 68 69 0d 09 62 6c 73 |a..bsr..|bhi..bls|
|00000400| 0d 09 62 63 63 0d 09 62 | 63 73 0d 09 62 6e 65 0d |..bcc..b|cs..bne.|
|00000410| 09 62 65 71 0d 09 62 76 | 63 0d 09 62 76 73 0d 09 |.beq..bv|c..bvs..|
|00000420| 62 70 6c 0d 09 62 6d 69 | 0d 09 62 67 65 0d 09 62 |bpl..bmi|..bge..b|
|00000430| 6c 74 0d 09 62 67 74 0d | 09 62 6c 65 0d 09 6d 6f |lt..bgt.|.ble..mo|
|00000440| 76 65 6d 2e 6c 0d 29 29 | 29 0d 0d 28 64 65 66 63 |vem.l.))|)..(defc|
|00000450| 6f 6e 73 74 61 6e 74 20 | 61 30 20 30 29 0d 28 64 |onstant |a0 0).(d|
|00000460| 65 66 63 6f 6e 73 74 61 | 6e 74 20 61 31 20 31 29 |efconsta|nt a1 1)|
|00000470| 0d 28 64 65 66 63 6f 6e | 73 74 61 6e 74 20 61 32 |.(defcon|stant a2|
|00000480| 20 32 29 0d 28 64 65 66 | 63 6f 6e 73 74 61 6e 74 | 2).(def|constant|
|00000490| 20 61 33 20 33 29 0d 28 | 64 65 66 63 6f 6e 73 74 | a3 3).(|defconst|
|000004a0| 61 6e 74 20 61 34 20 34 | 29 0d 28 64 65 66 63 6f |ant a4 4|).(defco|
|000004b0| 6e 73 74 61 6e 74 20 61 | 35 20 35 29 0d 28 64 65 |nstant a|5 5).(de|
|000004c0| 66 63 6f 6e 73 74 61 6e | 74 20 61 36 20 36 29 0d |fconstan|t a6 6).|
|000004d0| 28 64 65 66 63 6f 6e 73 | 74 61 6e 74 20 61 37 20 |(defcons|tant a7 |
|000004e0| 37 29 0d 0d 28 64 65 66 | 63 6f 6e 73 74 61 6e 74 |7)..(def|constant|
|000004f0| 20 61 30 2b 20 30 29 0d | 28 64 65 66 63 6f 6e 73 | a0+ 0).|(defcons|
|00000500| 74 61 6e 74 20 61 31 2b | 20 31 29 0d 28 64 65 66 |tant a1+| 1).(def|
|00000510| 63 6f 6e 73 74 61 6e 74 | 20 61 32 2b 20 32 29 0d |constant| a2+ 2).|
|00000520| 28 64 65 66 63 6f 6e 73 | 74 61 6e 74 20 61 33 2b |(defcons|tant a3+|
|00000530| 20 33 29 0d 28 64 65 66 | 63 6f 6e 73 74 61 6e 74 | 3).(def|constant|
|00000540| 20 61 34 2b 20 34 29 0d | 28 64 65 66 63 6f 6e 73 | a4+ 4).|(defcons|
|00000550| 74 61 6e 74 20 61 35 2b | 20 35 29 0d 28 64 65 66 |tant a5+| 5).(def|
|00000560| 63 6f 6e 73 74 61 6e 74 | 20 61 36 2b 20 36 29 0d |constant| a6+ 6).|
|00000570| 28 64 65 66 63 6f 6e 73 | 74 61 6e 74 20 61 37 2b |(defcons|tant a7+|
|00000580| 20 37 29 0d 0d 28 64 65 | 66 63 6f 6e 73 74 61 6e | 7)..(de|fconstan|
|00000590| 74 20 2d 61 30 20 30 29 | 0d 28 64 65 66 63 6f 6e |t -a0 0)|.(defcon|
|000005a0| 73 74 61 6e 74 20 2d 61 | 31 20 31 29 0d 28 64 65 |stant -a|1 1).(de|
|000005b0| 66 63 6f 6e 73 74 61 6e | 74 20 2d 61 32 20 32 29 |fconstan|t -a2 2)|
|000005c0| 0d 28 64 65 66 63 6f 6e | 73 74 61 6e 74 20 2d 61 |.(defcon|stant -a|
|000005d0| 33 20 33 29 0d 28 64 65 | 66 63 6f 6e 73 74 61 6e |3 3).(de|fconstan|
|000005e0| 74 20 2d 61 34 20 34 29 | 0d 28 64 65 66 63 6f 6e |t -a4 4)|.(defcon|
|000005f0| 73 74 61 6e 74 20 2d 61 | 35 20 35 29 0d 28 64 65 |stant -a|5 5).(de|
|00000600| 66 63 6f 6e 73 74 61 6e | 74 20 2d 61 36 20 36 29 |fconstan|t -a6 6)|
|00000610| 0d 28 64 65 66 63 6f 6e | 73 74 61 6e 74 20 2d 61 |.(defcon|stant -a|
|00000620| 37 20 37 29 0d 0d 28 64 | 65 66 63 6f 6e 73 74 61 |7 7)..(d|efconsta|
|00000630| 6e 74 20 64 30 20 30 29 | 0d 28 64 65 66 63 6f 6e |nt d0 0)|.(defcon|
|00000640| 73 74 61 6e 74 20 64 31 | 20 31 29 0d 28 64 65 66 |stant d1| 1).(def|
|00000650| 63 6f 6e 73 74 61 6e 74 | 20 64 32 20 32 29 0d 28 |constant| d2 2).(|
|00000660| 64 65 66 63 6f 6e 73 74 | 61 6e 74 20 64 33 20 33 |defconst|ant d3 3|
|00000670| 29 0d 28 64 65 66 63 6f | 6e 73 74 61 6e 74 20 64 |).(defco|nstant d|
|00000680| 34 20 34 29 0d 28 64 65 | 66 63 6f 6e 73 74 61 6e |4 4).(de|fconstan|
|00000690| 74 20 64 35 20 35 29 0d | 28 64 65 66 63 6f 6e 73 |t d5 5).|(defcons|
|000006a0| 74 61 6e 74 20 64 36 20 | 36 29 0d 28 64 65 66 63 |tant d6 |6).(defc|
|000006b0| 6f 6e 73 74 61 6e 74 20 | 64 37 20 37 29 0d 0d 28 |onstant |d7 7)..(|
|000006c0| 64 65 66 63 6f 6e 73 74 | 61 6e 74 20 64 2d 72 65 |defconst|ant d-re|
|000006d0| 67 69 73 74 65 72 73 20 | 27 28 64 30 20 64 31 20 |gisters |'(d0 d1 |
|000006e0| 64 32 20 64 33 20 64 34 | 20 64 35 20 64 36 20 64 |d2 d3 d4| d5 d6 d|
|000006f0| 37 29 29 0d 28 64 65 66 | 63 6f 6e 73 74 61 6e 74 |7)).(def|constant|
|00000700| 20 61 2d 72 65 67 69 73 | 74 65 72 73 20 27 28 61 | a-regis|ters '(a|
|00000710| 30 20 61 31 20 61 32 20 | 61 33 20 61 34 20 61 35 |0 a1 a2 |a3 a4 a5|
|00000720| 20 61 36 20 61 37 29 29 | 0d 28 64 65 66 63 6f 6e | a6 a7))|.(defcon|
|00000730| 73 74 61 6e 74 20 61 2d | 69 6e 63 2d 72 65 67 69 |stant a-|inc-regi|
|00000740| 73 74 65 72 73 20 27 28 | 61 30 2b 20 61 31 2b 20 |sters '(|a0+ a1+ |
|00000750| 61 32 2b 20 61 33 2b 20 | 61 34 2b 20 61 35 2b 20 |a2+ a3+ |a4+ a5+ |
|00000760| 61 36 2b 20 61 37 2b 29 | 29 0d 28 64 65 66 63 6f |a6+ a7+)|).(defco|
|00000770| 6e 73 74 61 6e 74 20 61 | 2d 64 65 63 2d 72 65 67 |nstant a|-dec-reg|
|00000780| 69 73 74 65 72 73 20 27 | 28 2d 61 30 20 2d 61 31 |isters '|(-a0 -a1|
|00000790| 20 2d 61 32 20 2d 61 33 | 20 2d 61 34 20 2d 61 35 | -a2 -a3| -a4 -a5|
|000007a0| 20 2d 61 36 20 2d 61 37 | 29 29 0d 0d 3b 3b 09 4d | -a6 -a7|))..;;.M|
|000007b0| 61 63 72 6f 73 20 74 6f | 20 61 63 63 65 73 73 20 |acros to| access |
|000007c0| 53 59 4d 42 4f 4c 20 61 | 6e 64 20 4e 4f 44 45 20 |SYMBOL a|nd NODE |
|000007d0| 66 69 65 6c 64 73 2e 0d | 3b 3b 09 54 68 65 73 65 |fields..|;;.These|
|000007e0| 20 61 72 65 20 64 65 70 | 65 6e 64 65 6e 74 20 6f | are dep|endent o|
|000007f0| 6e 20 74 68 65 20 73 79 | 6d 62 6f 6c 20 63 6c 61 |n the sy|mbol cla|
|00000800| 73 73 20 64 65 66 69 6e | 69 74 69 6f 6e 2e 0d 3b |ss defin|ition..;|
|00000810| 3b 09 54 68 65 20 43 2b | 2b 20 73 6f 75 72 63 65 |;.The C+|+ source|
|00000820| 20 69 73 20 69 6e 20 4c | 69 73 70 4f 62 6a 65 63 | is in L|ispObjec|
|00000830| 74 73 2e 68 2e 0d 0d 28 | 64 65 66 63 6f 6e 73 74 |ts.h...(|defconst|
|00000840| 61 6e 74 20 2a 73 79 6d | 62 6f 6c 2d 76 61 6c 75 |ant *sym|bol-valu|
|00000850| 65 2d 6f 66 66 73 65 74 | 2a 20 09 09 09 09 38 29 |e-offset|* ....8)|
|00000860| 0d 28 64 65 66 63 6f 6e | 73 74 61 6e 74 20 2a 73 |.(defcon|stant *s|
|00000870| 79 6d 62 6f 6c 2d 70 6c | 69 73 74 2d 6f 66 66 73 |ymbol-pl|ist-offs|
|00000880| 65 74 2a 20 09 09 09 09 | 31 32 29 0d 28 64 65 66 |et* ....|12).(def|
|00000890| 63 6f 6e 73 74 61 6e 74 | 20 2a 73 79 6d 62 6f 6c |constant| *symbol|
|000008a0| 2d 70 61 63 6b 61 67 65 | 2d 6f 66 66 73 65 74 2a |-package|-offset*|
|000008b0| 20 09 09 09 31 36 29 0d | 28 64 65 66 63 6f 6e 73 | ...16).|(defcons|
|000008c0| 74 61 6e 74 20 2a 73 79 | 6d 62 6f 6c 2d 6e 61 6d |tant *sy|mbol-nam|
|000008d0| 65 2d 6f 66 66 73 65 74 | 2a 20 09 09 09 09 32 30 |e-offset|* ....20|
|000008e0| 29 0d 28 64 65 66 63 6f | 6e 73 74 61 6e 74 20 2a |).(defco|nstant *|
|000008f0| 73 79 6d 62 6f 6c 2d 66 | 6c 61 67 73 2d 6f 66 66 |symbol-f|lags-off|
|00000900| 73 65 74 2a 20 09 09 09 | 09 32 34 29 0d 28 64 65 |set* ...|.24).(de|
|00000910| 66 63 6f 6e 73 74 61 6e | 74 20 2a 73 79 6d 62 6f |fconstan|t *symbo|
|00000920| 6c 2d 6a 75 6d 70 2d 74 | 61 62 6c 65 2d 65 6e 74 |l-jump-t|able-ent|
|00000930| 72 79 2d 6f 66 66 73 65 | 74 2a 20 09 32 36 29 0d |ry-offse|t* .26).|
|00000940| 28 64 65 66 63 6f 6e 73 | 74 61 6e 74 20 2a 73 79 |(defcons|tant *sy|
|00000950| 6d 62 6f 6c 2d 6a 75 6d | 70 2d 61 64 64 72 65 73 |mbol-jum|p-addres|
|00000960| 73 2d 6f 66 66 73 65 74 | 2a 20 09 09 32 38 29 0d |s-offset|* ..28).|
|00000970| 28 64 65 66 63 6f 6e 73 | 74 61 6e 74 20 2a 73 79 |(defcons|tant *sy|
|00000980| 6d 62 6f 6c 2d 66 75 6e | 63 74 69 6f 6e 2d 6f 66 |mbol-fun|ction-of|
|00000990| 66 73 65 74 2a 20 09 09 | 09 33 32 29 0d 0d 28 64 |fset* ..|.32)..(d|
|000009a0| 65 66 63 6f 6e 73 74 61 | 6e 74 20 2a 6e 6f 64 65 |efconsta|nt *node|
|000009b0| 2d 63 61 72 2d 6f 66 66 | 73 65 74 2a 09 09 09 09 |-car-off|set*....|
|000009c0| 09 30 29 0d 28 64 65 66 | 63 6f 6e 73 74 61 6e 74 |.0).(def|constant|
|000009d0| 20 2a 6e 6f 64 65 2d 63 | 64 72 2d 6f 66 66 73 65 | *node-c|dr-offse|
|000009e0| 74 2a 09 09 09 09 09 34 | 29 0d 28 64 65 66 63 6f |t*.....4|).(defco|
|000009f0| 6e 73 74 61 6e 74 20 2a | 6e 6f 64 65 2d 66 6c 61 |nstant *|node-fla|
|00000a00| 67 73 2d 6f 66 66 73 65 | 74 2a 09 09 09 09 38 29 |gs-offse|t*....8)|
|00000a10| 0d 28 64 65 66 63 6f 6e | 73 74 61 6e 74 20 2a 6e |.(defcon|stant *n|
|00000a20| 6f 64 65 2d 74 79 70 65 | 2d 6f 66 66 73 65 74 2a |ode-type|-offset*|
|00000a30| 09 09 09 09 09 39 29 0d | 0d 28 64 65 66 63 6f 6e |.....9).|.(defcon|
|00000a40| 73 74 61 6e 74 20 2a 6e | 6f 64 65 2d 69 6e 74 65 |stant *n|ode-inte|
|00000a50| 67 65 72 2d 6f 66 66 73 | 65 74 2a 09 09 09 09 30 |ger-offs|et*....0|
|00000a60| 29 09 3b 3b 20 6f 63 63 | 75 70 69 65 73 20 74 68 |).;; occ|upies th|
|00000a70| 65 20 63 61 72 20 66 69 | 65 6c 64 0d 0d 28 64 65 |e car fi|eld..(de|
|00000a80| 66 76 61 72 20 2a 61 73 | 73 65 6d 62 6c 65 72 2d |fvar *as|sembler-|
|00000a90| 61 64 64 72 65 73 73 2a | 09 30 29 0d 28 64 65 66 |address*|.0).(def|
|00000aa0| 76 61 72 20 2a 61 73 73 | 65 6d 62 6c 65 72 2d 6c |var *ass|embler-l|
|00000ab0| 6f 63 61 6c 2d 61 64 64 | 72 65 73 73 2a 09 30 29 |ocal-add|ress*.0)|
|00000ac0| 09 3b 3b 20 6b 65 65 70 | 20 74 72 61 63 6b 20 6f |.;; keep| track o|
|00000ad0| 66 20 6f 66 66 73 65 74 | 20 77 69 74 68 69 6e 20 |f offset| within |
|00000ae0| 69 6e 73 74 72 75 63 74 | 69 6f 6e 0d 28 64 65 66 |instruct|ion.(def|
|00000af0| 76 61 72 20 2a 61 73 73 | 65 6d 62 6c 65 72 2d 72 |var *ass|embler-r|
|00000b00| 65 66 65 72 65 6e 63 65 | 73 2a 09 6e 69 6c 29 0d |eference|s*.nil).|
|00000b10| 0d 3b 0d 3b 09 57 65 20 | 64 6f 20 61 6e 20 65 76 |.;.;.We |do an ev|
|00000b20| 61 6c 2d 77 68 65 6e 20 | 6f 6e 20 74 68 65 20 65 |al-when |on the e|
|00000b30| 6e 74 69 72 65 20 66 69 | 6c 65 20 73 6f 20 74 68 |ntire fi|le so th|
|00000b40| 61 74 20 77 65 20 67 65 | 74 20 74 68 65 0d 3b 09 |at we ge|t the.;.|
|00000b50| 70 65 72 66 6f 72 6d 61 | 6e 63 65 20 62 65 6e 65 |performa|nce bene|
|00000b60| 66 69 74 73 20 69 6d 6d | 65 64 69 61 74 65 6c 79 |fits imm|ediately|
|00000b70| 0d 3b 0d 28 65 76 61 6c | 2d 77 68 65 6e 20 28 3a |.;.(eval|-when (:|
|00000b80| 63 6f 6d 70 69 6c 65 2d | 74 6f 70 6c 65 76 65 6c |compile-|toplevel|
|00000b90| 20 3a 6c 6f 61 64 2d 74 | 6f 70 6c 65 76 65 6c 20 | :load-t|oplevel |
|00000ba0| 3a 65 78 65 63 75 74 65 | 29 0d 0d 28 64 65 66 6d |:execute|)..(defm|
|00000bb0| 61 63 72 6f 20 24 43 41 | 52 20 28 61 72 65 67 20 |acro $CA|R (areg |
|00000bc0| 26 6f 70 74 69 6f 6e 61 | 6c 20 64 65 73 74 2d 72 |&optiona|l dest-r|
|00000bd0| 65 67 29 0d 09 28 75 6e | 6c 65 73 73 20 64 65 73 |eg)..(un|less des|
|00000be0| 74 2d 72 65 67 20 28 73 | 65 74 71 20 64 65 73 74 |t-reg (s|etq dest|
|00000bf0| 2d 72 65 67 20 61 72 65 | 67 29 29 0d 09 60 28 0d |-reg are|g))..`(.|
|00000c00| 09 09 28 6d 6f 76 65 2e | 6c 20 28 2c 61 72 65 67 |..(move.|l (,areg|
|00000c10| 20 2c 2a 6e 6f 64 65 2d | 63 61 72 2d 6f 66 66 73 | ,*node-|car-offs|
|00000c20| 65 74 2a 29 20 2c 64 65 | 73 74 2d 72 65 67 29 0d |et*) ,de|st-reg).|
|00000c30| 09 20 29 29 20 0d 0d 28 | 64 65 66 6d 61 63 72 6f |. )) ..(|defmacro|
|00000c40| 20 24 43 44 52 20 28 61 | 72 65 67 20 26 6f 70 74 | $CDR (a|reg &opt|
|00000c50| 69 6f 6e 61 6c 20 64 65 | 73 74 2d 72 65 67 29 0d |ional de|st-reg).|
|00000c60| 09 28 75 6e 6c 65 73 73 | 20 64 65 73 74 2d 72 65 |.(unless| dest-re|
|00000c70| 67 20 28 73 65 74 71 20 | 64 65 73 74 2d 72 65 67 |g (setq |dest-reg|
|00000c80| 20 61 72 65 67 29 29 0d | 09 60 28 0d 09 09 28 6d | areg)).|.`(...(m|
|00000c90| 6f 76 65 2e 6c 20 28 2c | 61 72 65 67 20 2c 2a 6e |ove.l (,|areg ,*n|
|00000ca0| 6f 64 65 2d 63 64 72 2d | 6f 66 66 73 65 74 2a 29 |ode-cdr-|offset*)|
|00000cb0| 20 2c 64 65 73 74 2d 72 | 65 67 29 0d 09 20 29 29 | ,dest-r|eg).. ))|
|00000cc0| 20 0d 0d 28 64 65 66 6d | 61 63 72 6f 20 24 53 45 | ..(defm|acro $SE|
|00000cd0| 54 43 41 52 20 28 61 72 | 65 67 20 76 61 6c 75 65 |TCAR (ar|eg value|
|00000ce0| 29 0d 09 60 28 0d 09 09 | 28 6d 6f 76 65 2e 6c 20 |)..`(...|(move.l |
|00000cf0| 2c 76 61 6c 75 65 20 28 | 2c 61 72 65 67 20 2c 2a |,value (|,areg ,*|
|00000d00| 6e 6f 64 65 2d 63 61 72 | 2d 6f 66 66 73 65 74 2a |node-car|-offset*|
|00000d10| 29 29 0d 09 20 29 29 20 | 0d 0d 28 64 65 66 6d 61 |)).. )) |..(defma|
|00000d20| 63 72 6f 20 24 53 45 54 | 43 44 52 20 28 61 72 65 |cro $SET|CDR (are|
|00000d30| 67 20 76 61 6c 75 65 29 | 0d 09 60 28 0d 09 09 28 |g value)|..`(...(|
|00000d40| 6d 6f 76 65 2e 6c 20 2c | 76 61 6c 75 65 20 28 2c |move.l ,|value (,|
|00000d50| 61 72 65 67 20 2c 2a 6e | 6f 64 65 2d 63 64 72 2d |areg ,*n|ode-cdr-|
|00000d60| 6f 66 66 73 65 74 2a 29 | 29 0d 09 20 29 29 20 0d |offset*)|).. )) .|
|00000d70| 0d 28 64 65 66 6d 61 63 | 72 6f 20 24 53 59 4d 42 |.(defmac|ro $SYMB|
|00000d80| 4f 4c 2d 56 41 4c 55 45 | 20 28 61 72 65 67 29 0d |OL-VALUE| (areg).|
|00000d90| 09 60 28 0d 09 09 28 6d | 6f 76 65 2e 6c 20 28 2c |.`(...(m|ove.l (,|
|00000da0| 61 72 65 67 29 20 2c 61 | 72 65 67 29 0d 09 09 28 |areg) ,a|reg)...(|
|00000db0| 6d 6f 76 65 2e 6c 20 28 | 2c 61 72 65 67 20 2c 2a |move.l (|,areg ,*|
|00000dc0| 73 79 6d 62 6f 6c 2d 76 | 61 6c 75 65 2d 6f 66 66 |symbol-v|alue-off|
|00000dd0| 73 65 74 2a 29 20 2c 61 | 72 65 67 29 0d 09 09 28 |set*) ,a|reg)...(|
|00000de0| 6d 6f 76 65 2e 6c 20 28 | 2c 61 72 65 67 29 20 2c |move.l (|,areg) ,|
|00000df0| 61 72 65 67 29 0d 09 20 | 29 29 20 0d 0d 28 64 65 |areg).. |)) ..(de|
|00000e00| 66 6d 61 63 72 6f 20 24 | 53 59 4d 42 4f 4c 2d 50 |fmacro $|SYMBOL-P|
|00000e10| 4c 49 53 54 20 28 61 72 | 65 67 29 0d 09 60 28 0d |LIST (ar|eg)..`(.|
|00000e20| 09 09 28 6d 6f 76 65 2e | 6c 20 28 2c 61 72 65 67 |..(move.|l (,areg|
|00000e30| 29 20 2c 61 72 65 67 29 | 0d 09 09 28 6d 6f 76 65 |) ,areg)|...(move|
|00000e40| 2e 6c 20 28 2c 61 72 65 | 67 20 2c 2a 73 79 6d 62 |.l (,are|g ,*symb|
|00000e50| 6f 6c 2d 70 6c 69 73 74 | 2d 6f 66 66 73 65 74 2a |ol-plist|-offset*|
|00000e60| 29 20 2c 61 72 65 67 29 | 0d 09 20 29 29 20 0d 0d |) ,areg)|.. )) ..|
|00000e70| 3b 3b 20 45 78 74 72 61 | 63 74 20 74 68 65 20 74 |;; Extra|ct the t|
|00000e80| 79 70 65 20 66 69 65 6c | 64 20 66 72 6f 6d 20 61 |ype fiel|d from a|
|00000e90| 20 6e 6f 64 65 0d 28 64 | 65 66 6d 61 63 72 6f 20 | node.(d|efmacro |
|00000ea0| 24 4e 4f 44 45 2d 54 59 | 50 45 20 28 61 72 65 67 |$NODE-TY|PE (areg|
|00000eb0| 20 64 65 73 74 29 0d 09 | 60 28 0d 09 09 28 6d 6f | dest)..|`(...(mo|
|00000ec0| 76 65 2e 6c 20 28 2c 61 | 72 65 67 20 2c 28 2d 20 |ve.l (,a|reg ,(- |
|00000ed0| 2a 6e 6f 64 65 2d 74 79 | 70 65 2d 6f 66 66 73 65 |*node-ty|pe-offse|
|00000ee0| 74 2a 20 33 29 29 20 2c | 64 65 73 74 29 0d 09 09 |t* 3)) ,|dest)...|
|00000ef0| 28 61 6e 64 69 2e 6c 20 | 23 78 30 30 30 30 30 30 |(andi.l |#x000000|
|00000f00| 66 66 20 2c 64 65 73 74 | 29 0d 09 29 29 0d 09 0d |ff ,dest|)..))...|
|00000f10| 28 64 65 66 6d 61 63 72 | 6f 20 24 43 4f 4e 53 50 |(defmacr|o $CONSP|
|00000f20| 20 28 61 72 65 67 29 0d | 09 60 28 0d 09 09 28 24 | (areg).|.`(...($|
|00000f30| 4e 4f 44 45 2d 54 59 50 | 45 20 2c 61 72 65 67 20 |NODE-TYP|E ,areg |
|00000f40| 64 30 29 0d 09 09 28 63 | 6d 70 2e 6c 20 30 20 64 |d0)...(c|mp.l 0 d|
|00000f50| 30 29 0d 09 29 29 0d 0d | 28 64 65 66 6d 61 63 72 |0)..))..|(defmacr|
|00000f60| 6f 20 24 49 4e 54 45 47 | 45 52 20 28 61 72 65 67 |o $INTEG|ER (areg|
|00000f70| 20 26 6f 70 74 69 6f 6e | 61 6c 20 64 65 73 74 2d | &option|al dest-|
|00000f80| 72 65 67 29 0d 09 28 75 | 6e 6c 65 73 73 20 64 65 |reg)..(u|nless de|
|00000f90| 73 74 2d 72 65 67 20 28 | 73 65 74 71 20 64 65 73 |st-reg (|setq des|
|00000fa0| 74 2d 72 65 67 20 61 72 | 65 67 29 29 0d 09 60 28 |t-reg ar|eg))..`(|
|00000fb0| 0d 09 09 28 6d 6f 76 65 | 2e 6c 20 28 2c 61 72 65 |...(move|.l (,are|
|00000fc0| 67 20 2c 2a 6e 6f 64 65 | 2d 69 6e 74 65 67 65 72 |g ,*node|-integer|
|00000fd0| 2d 6f 66 66 73 65 74 2a | 29 20 2c 64 65 73 74 2d |-offset*|) ,dest-|
|00000fe0| 72 65 67 29 0d 09 20 29 | 29 20 0d 0d 09 0d 3b 3b |reg).. )|) ....;;|
|00000ff0| 0d 3b 3b 09 54 68 65 20 | 24 52 45 54 55 52 4e 20 |.;;.The |$RETURN |
|00001000| 6d 61 63 72 6f 20 7a 65 | 72 6f 73 20 6f 75 74 20 |macro ze|ros out |
|00001010| 74 68 65 20 6d 75 6c 74 | 69 70 6c 65 20 76 61 6c |the mult|iple val|
|00001020| 75 65 20 63 65 6c 6c 2c | 20 73 74 6f 72 65 73 0d |ue cell,| stores.|
|00001030| 3b 3b 09 74 68 65 20 70 | 61 73 73 65 64 20 76 61 |;;.the p|assed va|
|00001040| 6c 75 65 20 69 6e 20 64 | 30 20 28 74 6f 20 72 65 |lue in d|0 (to re|
|00001050| 74 75 72 6e 20 69 74 29 | 2c 20 61 6e 64 20 75 6e |turn it)|, and un|
|00001060| 6c 69 6e 6b 73 20 74 68 | 65 20 73 74 61 63 6b 20 |links th|e stack |
|00001070| 66 72 61 6d 65 2e 0d 3b | 3b 0d 28 64 65 66 6d 61 |frame..;|;.(defma|
|00001080| 63 72 6f 20 24 52 45 54 | 55 52 4e 20 28 72 65 74 |cro $RET|URN (ret|
|00001090| 76 61 6c 29 0d 09 28 69 | 66 20 28 65 71 20 72 65 |val)..(i|f (eq re|
|000010a0| 74 76 61 6c 20 27 64 30 | 29 0d 09 09 60 28 0d 09 |tval 'd0|)...`(..|
|000010b0| 09 09 28 63 6c 72 2e 6c | 20 28 63 6f 6d 6d 6f 6e |..(clr.l| (common|
|000010c0| 2d 6c 69 73 70 3a 3a 25 | 6d 75 6c 74 69 70 6c 65 |-lisp::%|multiple|
|000010d0| 2d 76 61 6c 75 65 73 2d | 61 64 64 72 65 73 73 29 |-values-|address)|
|000010e0| 29 0d 09 09 09 28 75 6e | 6c 6b 20 61 36 29 0d 09 |)....(un|lk a6)..|
|000010f0| 09 09 28 72 74 73 29 0d | 09 20 09 29 20 0d 09 09 |..(rts).|. .) ...|
|00001100| 60 28 0d 09 09 09 28 63 | 6c 72 2e 6c 20 28 63 6f |`(....(c|lr.l (co|
|00001110| 6d 6d 6f 6e 2d 6c 69 73 | 70 3a 3a 25 6d 75 6c 74 |mmon-lis|p::%mult|
|00001120| 69 70 6c 65 2d 76 61 6c | 75 65 73 2d 61 64 64 72 |iple-val|ues-addr|
|00001130| 65 73 73 29 29 0d 09 09 | 09 28 6d 6f 76 65 2e 6c |ess))...|.(move.l|
|00001140| 20 2c 72 65 74 76 61 6c | 20 64 30 29 0d 09 09 09 | ,retval| d0)....|
|00001150| 28 75 6e 6c 6b 20 61 36 | 29 0d 09 09 09 28 72 74 |(unlk a6|)....(rt|
|00001160| 73 29 0d 09 20 09 29 29 | 29 20 0d 0d 3b 3b 0d 3b |s).. .))|) ..;;.;|
|00001170| 3b 09 54 68 65 20 24 46 | 55 4e 43 2d 42 45 47 49 |;.The $F|UNC-BEGI|
|00001180| 4e 20 6d 61 63 72 6f 20 | 73 65 74 73 20 75 70 20 |N macro |sets up |
|00001190| 74 68 65 20 41 36 20 73 | 74 61 63 6b 20 66 72 61 |the A6 s|tack fra|
|000011a0| 6d 65 20 6c 69 6e 6b 2c | 0d 3b 3b 09 61 6e 64 20 |me link,|.;;.and |
|000011b0| 73 74 6f 72 65 73 20 61 | 20 70 6f 69 6e 74 65 72 |stores a| pointer|
|000011c0| 20 74 6f 20 74 68 65 20 | 70 61 72 61 6d 65 74 65 | to the |paramete|
|000011d0| 72 20 62 6c 6f 63 6b 20 | 69 6e 20 41 30 2e 0d 3b |r block |in A0..;|
|000011e0| 3b 09 55 73 61 67 65 3a | 0d 3b 3b 09 09 28 24 46 |;.Usage:|.;;..($F|
|000011f0| 55 4e 43 2d 42 45 47 49 | 4e 20 34 29 09 09 3b 3b |UNC-BEGI|N 4)..;;|
|00001200| 20 61 6c 6c 6f 63 61 74 | 65 73 20 34 20 62 79 74 | allocat|es 4 byt|
|00001210| 65 73 20 28 73 70 61 63 | 65 20 66 6f 72 20 6f 6e |es (spac|e for on|
|00001220| 65 20 6f 62 6a 65 63 74 | 29 0d 3b 3b 09 09 09 09 |e object|).;;....|
|00001230| 09 09 09 3b 3b 20 6f 6e | 20 74 68 65 20 73 74 61 |...;; on| the sta|
|00001240| 63 6b 0d 3b 3b 0d 28 64 | 65 66 6d 61 63 72 6f 20 |ck.;;.(d|efmacro |
|00001250| 24 46 55 4e 43 2d 42 45 | 47 49 4e 20 28 73 69 7a |$FUNC-BE|GIN (siz|
|00001260| 65 29 0d 09 60 28 0d 09 | 09 28 6c 69 6e 6b 20 61 |e)..`(..|.(link a|
|00001270| 36 20 2c 73 69 7a 65 29 | 0d 09 09 28 6d 6f 76 65 |6 ,size)|...(move|
|00001280| 2e 6c 20 28 61 36 20 38 | 29 20 61 30 29 0d 09 20 |.l (a6 8|) a0).. |
|00001290| 29 29 20 0d 0d 3b 3b 0d | 3b 3b 09 24 49 46 20 6d |)) ..;;.|;;.$IF m|
|000012a0| 61 63 72 6f 0d 3b 3b 09 | 55 73 61 67 65 3a 0d 3b |acro.;;.|Usage:.;|
|000012b0| 3b 09 09 28 24 49 46 09 | 0d 3b 3b 09 09 09 28 63 |;..($IF.|.;;...(c|
|000012c0| 6d 70 2e 6c 20 64 33 20 | 30 29 20 09 09 3b 3b 20 |mp.l d3 |0) ..;; |
|000012d0| 69 66 20 64 33 20 3d 3d | 20 30 20 74 68 65 20 6e |if d3 ==| 0 the n|
|000012e0| 65 78 74 20 73 74 61 74 | 65 6d 65 6e 74 20 77 69 |ext stat|ement wi|
|000012f0| 6c 6c 20 62 65 20 65 78 | 65 63 75 74 65 64 0d 3b |ll be ex|ecuted.;|
|00001300| 3b 09 09 09 28 0d 3b 3b | 09 09 09 09 28 6d 6f 76 |;...(.;;|....(mov|
|00001310| 65 2e 6c 20 64 30 20 64 | 33 29 0d 3b 3b 09 09 09 |e.l d0 d|3).;;...|
|00001320| 29 29 0d 3b 3b 0d 28 64 | 65 66 6d 61 63 72 6f 20 |)).;;.(d|efmacro |
|00001330| 24 49 46 20 28 63 6f 6e | 64 69 74 69 6f 6e 20 69 |$IF (con|dition i|
|00001340| 6e 73 74 72 75 63 74 69 | 6f 6e 73 29 0d 09 28 6c |nstructi|ons)..(l|
|00001350| 65 74 20 28 28 74 65 6d | 70 2d 6c 61 62 65 6c 20 |et ((tem|p-label |
|00001360| 28 67 65 6e 73 79 6d 29 | 29 29 0d 09 09 3b 3b 09 |(gensym)|))...;;.|
|00001370| 61 6c 6c 6f 77 20 73 69 | 6e 67 6c 65 20 69 6e 73 |allow si|ngle ins|
|00001380| 74 72 75 63 74 69 6f 6e | 20 63 6c 61 75 73 65 73 |truction| clauses|
|00001390| 20 6f 72 20 6c 69 73 74 | 73 20 6f 66 20 69 6e 73 | or list|s of ins|
|000013a0| 74 72 75 63 74 69 6f 6e | 73 0d 09 09 28 69 66 20 |truction|s...(if |
|000013b0| 28 6e 6f 74 20 28 6c 69 | 73 74 70 20 28 63 61 72 |(not (li|stp (car|
|000013c0| 20 63 6f 6e 64 69 74 69 | 6f 6e 29 29 29 0d 09 09 | conditi|on)))...|
|000013d0| 09 28 73 65 74 71 20 63 | 6f 6e 64 69 74 69 6f 6e |.(setq c|ondition|
|000013e0| 20 28 6c 69 73 74 20 63 | 6f 6e 64 69 74 69 6f 6e | (list c|ondition|
|000013f0| 29 29 29 0d 09 09 28 69 | 66 20 28 6e 6f 74 20 28 |)))...(i|f (not (|
|00001400| 6c 69 73 74 70 20 28 63 | 61 72 20 69 6e 73 74 72 |listp (c|ar instr|
|00001410| 75 63 74 69 6f 6e 73 29 | 29 29 0d 09 09 09 28 73 |uctions)|))....(s|
|00001420| 65 74 71 20 69 6e 73 74 | 72 75 63 74 69 6f 6e 73 |etq inst|ructions|
|00001430| 20 28 6c 69 73 74 20 69 | 6e 73 74 72 75 63 74 69 | (list i|nstructi|
|00001440| 6f 6e 73 29 29 29 0d 0d | 09 09 60 28 0d 09 09 09 |ons)))..|..`(....|
|00001450| 2c 40 63 6f 6e 64 69 74 | 69 6f 6e 0d 09 09 09 28 |,@condit|ion....(|
|00001460| 62 6e 65 20 2c 74 65 6d | 70 2d 6c 61 62 65 6c 29 |bne ,tem|p-label)|
|00001470| 0d 09 09 09 2c 40 69 6e | 73 74 72 75 63 74 69 6f |....,@in|structio|
|00001480| 6e 73 0d 09 09 09 2c 74 | 65 6d 70 2d 6c 61 62 65 |ns....,t|emp-labe|
|00001490| 6c 0d 09 09 20 29 29 29 | 20 0d 0d 3b 3b 0d 3b 3b |l... )))| ..;;.;;|
|000014a0| 09 24 49 46 45 4c 53 45 | 20 6d 61 63 72 6f 0d 3b |.$IFELSE| macro.;|
|000014b0| 3b 09 55 73 61 67 65 3a | 0d 3b 3b 09 09 28 24 49 |;.Usage:|.;;..($I|
|000014c0| 46 45 4c 53 45 09 0d 3b | 3b 09 09 09 28 63 6d 70 |FELSE..;|;...(cmp|
|000014d0| 2e 6c 20 64 33 20 30 29 | 20 09 09 3b 3b 20 69 66 |.l d3 0)| ..;; if|
|000014e0| 20 64 33 20 3d 3d 20 30 | 20 74 68 65 20 6e 65 78 | d3 == 0| the nex|
|000014f0| 74 20 69 6e 73 74 72 75 | 63 74 69 6f 6e 20 77 69 |t instru|ction wi|
|00001500| 6c 6c 20 62 65 20 65 78 | 65 63 75 74 65 64 0d 3b |ll be ex|ecuted.;|
|00001510| 3b 09 09 09 28 0d 3b 3b | 09 09 09 09 28 6d 6f 76 |;...(.;;|....(mov|
|00001520| 65 2e 6c 20 64 30 20 64 | 33 29 0d 3b 3b 09 09 09 |e.l d0 d|3).;;...|
|00001530| 29 0d 3b 3b 09 09 09 28 | 0d 3b 3b 09 09 09 09 28 |).;;...(|.;;....(|
|00001540| 6d 6f 76 65 2e 6c 20 64 | 32 20 64 33 29 09 3b 3b |move.l d|2 d3).;;|
|00001550| 20 6f 74 68 65 72 77 69 | 73 65 20 74 68 69 73 20 | otherwi|se this |
|00001560| 69 6e 73 74 72 75 63 74 | 69 6f 6e 20 77 69 6c 6c |instruct|ion will|
|00001570| 20 62 65 20 65 78 65 63 | 75 74 65 64 0d 3b 3b 09 | be exec|uted.;;.|
|00001580| 09 09 29 29 0d 3b 3b 0d | 28 64 65 66 6d 61 63 72 |..)).;;.|(defmacr|
|00001590| 6f 20 24 49 46 45 4c 53 | 45 20 28 63 6f 6e 64 69 |o $IFELS|E (condi|
|000015a0| 74 69 6f 6e 20 69 66 2d | 69 6e 73 74 72 75 63 74 |tion if-|instruct|
|000015b0| 69 6f 6e 73 20 65 6c 73 | 65 2d 69 6e 73 74 72 75 |ions els|e-instru|
|000015c0| 63 74 69 6f 6e 73 29 0d | 09 28 6c 65 74 20 28 28 |ctions).|.(let ((|
|000015d0| 65 6c 73 65 2d 6c 61 62 | 65 6c 20 28 67 65 6e 73 |else-lab|el (gens|
|000015e0| 79 6d 29 29 20 0d 09 09 | 20 20 28 65 78 69 74 2d |ym)) ...| (exit-|
|000015f0| 6c 61 62 65 6c 20 28 67 | 65 6e 73 79 6d 29 29 29 |label (g|ensym)))|
|00001600| 0d 0d 09 09 3b 3b 09 61 | 6c 6c 6f 77 20 73 69 6e |....;;.a|llow sin|
|00001610| 67 6c 65 20 69 6e 73 74 | 72 75 63 74 69 6f 6e 20 |gle inst|ruction |
|00001620| 63 6c 61 75 73 65 73 20 | 6f 72 20 6c 69 73 74 73 |clauses |or lists|
|00001630| 20 6f 66 20 69 6e 73 74 | 72 75 63 74 69 6f 6e 73 | of inst|ructions|
|00001640| 0d 09 09 28 69 66 20 28 | 6e 6f 74 20 28 6c 69 73 |...(if (|not (lis|
|00001650| 74 70 20 28 63 61 72 20 | 63 6f 6e 64 69 74 69 6f |tp (car |conditio|
|00001660| 6e 29 29 29 0d 09 09 09 | 28 73 65 74 71 20 63 6f |n)))....|(setq co|
|00001670| 6e 64 69 74 69 6f 6e 20 | 28 6c 69 73 74 20 63 6f |ndition |(list co|
|00001680| 6e 64 69 74 69 6f 6e 29 | 29 29 0d 09 09 28 69 66 |ndition)|))...(if|
|00001690| 20 28 6e 6f 74 20 28 6c | 69 73 74 70 20 28 63 61 | (not (l|istp (ca|
|000016a0| 72 20 69 66 2d 69 6e 73 | 74 72 75 63 74 69 6f 6e |r if-ins|truction|
|000016b0| 73 29 29 29 0d 09 09 09 | 28 73 65 74 71 20 69 66 |s)))....|(setq if|
|000016c0| 2d 69 6e 73 74 72 75 63 | 74 69 6f 6e 73 20 28 6c |-instruc|tions (l|
|000016d0| 69 73 74 20 69 66 2d 69 | 6e 73 74 72 75 63 74 69 |ist if-i|nstructi|
|000016e0| 6f 6e 73 29 29 29 0d 09 | 09 28 69 66 20 28 6e 6f |ons)))..|.(if (no|
|000016f0| 74 20 28 6c 69 73 74 70 | 20 28 63 61 72 20 65 6c |t (listp| (car el|
|00001700| 73 65 2d 69 6e 73 74 72 | 75 63 74 69 6f 6e 73 29 |se-instr|uctions)|
|00001710| 29 29 0d 09 09 09 28 73 | 65 74 71 20 65 6c 73 65 |))....(s|etq else|
|00001720| 2d 69 6e 73 74 72 75 63 | 74 69 6f 6e 73 20 28 6c |-instruc|tions (l|
|00001730| 69 73 74 20 65 6c 73 65 | 2d 69 6e 73 74 72 75 63 |ist else|-instruc|
|00001740| 74 69 6f 6e 73 29 29 29 | 0d 09 09 0d 09 09 60 28 |tions)))|......`(|
|00001750| 0d 09 09 09 2c 40 63 6f | 6e 64 69 74 69 6f 6e 0d |....,@co|ndition.|
|00001760| 09 09 09 28 62 6e 65 20 | 2c 65 6c 73 65 2d 6c 61 |...(bne |,else-la|
|00001770| 62 65 6c 29 0d 09 09 09 | 2c 40 69 66 2d 69 6e 73 |bel)....|,@if-ins|
|00001780| 74 72 75 63 74 69 6f 6e | 73 0d 09 09 09 28 62 72 |truction|s....(br|
|00001790| 61 20 2c 65 78 69 74 2d | 6c 61 62 65 6c 29 0d 09 |a ,exit-|label)..|
|000017a0| 09 09 2c 65 6c 73 65 2d | 6c 61 62 65 6c 0d 09 09 |..,else-|label...|
|000017b0| 09 2c 40 65 6c 73 65 2d | 69 6e 73 74 72 75 63 74 |.,@else-|instruct|
|000017c0| 69 6f 6e 73 0d 09 09 09 | 2c 65 78 69 74 2d 6c 61 |ions....|,exit-la|
|000017d0| 62 65 6c 0d 09 09 20 29 | 29 29 20 0d 0d 3b 3b 0d |bel... )|)) ..;;.|
|000017e0| 3b 3b 09 54 68 65 20 24 | 52 45 46 45 52 45 4e 43 |;;.The $|REFERENC|
|000017f0| 45 20 6d 61 63 72 6f 20 | 64 6f 65 73 20 6e 6f 74 |E macro |does not|
|00001800| 20 67 65 6e 65 72 61 74 | 65 20 61 6e 79 20 69 6e | generat|e any in|
|00001810| 73 74 72 75 63 74 69 6f | 6e 73 2c 20 62 75 74 0d |structio|ns, but.|
|00001820| 3b 3b 09 69 73 20 75 73 | 65 64 20 62 79 20 74 68 |;;.is us|ed by th|
|00001830| 65 20 63 6f 6d 70 69 6c | 65 72 20 61 73 20 61 20 |e compil|er as a |
|00001840| 66 6c 61 67 20 74 6f 20 | 74 68 65 20 61 73 73 65 |flag to |the asse|
|00001850| 6d 62 6c 65 72 20 74 6f | 20 63 6f 72 72 65 63 74 |mbler to| correct|
|00001860| 6c 79 0d 3b 3b 09 67 65 | 6e 65 72 61 74 65 20 61 |ly.;;.ge|nerate a|
|00001870| 64 64 72 65 73 73 20 72 | 65 66 65 72 65 6e 63 65 |ddress r|eference|
|00001880| 20 65 6e 74 72 69 65 73 | 20 77 68 65 6e 20 63 6f | entries| when co|
|00001890| 64 65 20 69 73 20 63 6f | 6d 70 69 6c 65 64 20 74 |de is co|mpiled t|
|000018a0| 6f 20 61 20 66 69 6c 65 | 2e 0d 3b 3b 0d 28 64 65 |o a file|..;;.(de|
|000018b0| 66 6d 61 63 72 6f 20 24 | 52 45 46 45 52 45 4e 43 |fmacro $|REFERENC|
|000018c0| 45 20 28 72 65 66 65 72 | 65 6e 63 65 64 2d 69 74 |E (refer|enced-it|
|000018d0| 65 6d 29 0d 09 6e 69 6c | 29 0d 09 0d 28 64 65 66 |em)..nil|)...(def|
|000018e0| 6d 61 63 72 6f 20 6c 69 | 6e 6b 20 28 61 72 65 67 |macro li|nk (areg|
|000018f0| 20 6f 66 66 73 65 74 29 | 20 60 28 2c 28 2b 20 28 | offset)| `(,(+ (|
|00001900| 73 79 6d 62 6f 6c 2d 76 | 61 6c 75 65 20 61 72 65 |symbol-v|alue are|
|00001910| 67 29 20 23 78 34 65 35 | 30 29 20 2c 6f 66 66 73 |g) #x4e5|0) ,offs|
|00001920| 65 74 29 29 0d 28 64 65 | 66 6d 61 63 72 6f 20 75 |et)).(de|fmacro u|
|00001930| 6e 6c 6b 20 28 61 72 65 | 67 29 20 60 28 2c 28 2b |nlk (are|g) `(,(+|
|00001940| 20 28 73 79 6d 62 6f 6c | 2d 76 61 6c 75 65 20 61 | (symbol|-value a|
|00001950| 72 65 67 29 20 23 78 34 | 65 35 38 29 29 29 0d 28 |reg) #x4|e58))).(|
|00001960| 64 65 66 6d 61 63 72 6f | 20 72 74 73 20 28 29 20 |defmacro| rts () |
|00001970| 60 28 23 78 34 65 37 35 | 29 29 0d 28 64 65 66 6d |`(#x4e75|)).(defm|
|00001980| 61 63 72 6f 20 64 63 2e | 77 20 28 77 29 20 0d 09 |acro dc.|w (w) ..|
|00001990| 28 63 6f 6e 64 20 0d 09 | 09 28 28 73 79 6d 62 6f |(cond ..|.((symbo|
|000019a0| 6c 70 20 77 29 20 0d 09 | 09 20 28 61 64 64 2d 72 |lp w) ..|. (add-r|
|000019b0| 65 66 65 72 65 6e 63 65 | 20 60 28 25 73 79 6d 62 |eference| `(%symb|
|000019c0| 6f 6c 2d 76 61 6c 75 65 | 2d 77 6f 72 64 20 2c 77 |ol-value|-word ,w|
|000019d0| 29 20 2d 32 29 0d 09 09 | 20 28 6c 69 73 74 20 28 |) -2)...| (list (|
|000019e0| 73 79 6d 62 6f 6c 2d 76 | 61 6c 75 65 20 77 29 29 |symbol-v|alue w))|
|000019f0| 29 0d 09 09 28 74 20 28 | 6c 69 73 74 20 77 29 29 |)...(t (|list w))|
|00001a00| 29 29 0d 0d 28 64 65 66 | 6d 61 63 72 6f 20 64 63 |))..(def|macro dc|
|00001a10| 2e 6c 20 28 77 29 20 0d | 09 28 63 6f 6e 64 20 0d |.l (w) .|.(cond .|
|00001a20| 09 09 28 28 73 79 6d 62 | 6f 6c 70 20 77 29 20 0d |..((symb|olp w) .|
|00001a30| 09 09 20 28 61 64 64 2d | 72 65 66 65 72 65 6e 63 |.. (add-|referenc|
|00001a40| 65 20 60 28 25 73 79 6d | 62 6f 6c 2d 76 61 6c 75 |e `(%sym|bol-valu|
|00001a50| 65 20 2c 77 29 20 2d 32 | 29 0d 09 09 20 28 6d 75 |e ,w) -2|)... (mu|
|00001a60| 6c 74 69 70 6c 65 2d 76 | 61 6c 75 65 2d 6c 69 73 |ltiple-v|alue-lis|
|00001a70| 74 20 28 74 72 75 6e 63 | 61 74 65 20 28 73 79 6d |t (trunc|ate (sym|
|00001a80| 62 6f 6c 2d 76 61 6c 75 | 65 20 77 29 20 23 78 31 |bol-valu|e w) #x1|
|00001a90| 30 30 30 30 29 29 29 0d | 09 09 28 74 20 28 6d 75 |0000))).|..(t (mu|
|00001aa0| 6c 74 69 70 6c 65 2d 76 | 61 6c 75 65 2d 6c 69 73 |ltiple-v|alue-lis|
|00001ab0| 74 20 28 74 72 75 6e 63 | 61 74 65 20 77 20 23 78 |t (trunc|ate w #x|
|00001ac0| 31 30 30 30 30 29 29 29 | 29 29 0d 09 09 0d 28 64 |10000)))|))....(d|
|00001ad0| 65 66 6d 61 63 72 6f 20 | 6d 6f 76 65 71 20 28 62 |efmacro |moveq (b|
|00001ae0| 79 74 65 20 64 72 65 67 | 29 0d 09 28 69 66 20 28 |yte dreg|)..(if (|
|00001af0| 6f 72 20 28 3c 20 62 79 | 74 65 20 30 29 20 28 3e |or (< by|te 0) (>|
|00001b00| 20 62 79 74 65 20 32 35 | 35 29 29 20 0d 09 09 28 | byte 25|5)) ...(|
|00001b10| 65 72 72 6f 72 20 22 44 | 61 74 61 20 6f 75 74 20 |error "D|ata out |
|00001b20| 6f 66 20 72 61 6e 67 65 | 2e 7e 25 49 6e 73 74 72 |of range|.~%Instr|
|00001b30| 75 63 74 69 6f 6e 3a 20 | 6d 6f 76 65 71 20 20 56 |uction: |moveq V|
|00001b40| 61 6c 75 65 3a 20 7e 41 | 22 20 62 79 74 65 29 29 |alue: ~A|" byte))|
|00001b50| 0d 09 28 75 6e 6c 65 73 | 73 20 28 6d 65 6d 62 65 |..(unles|s (membe|
|00001b60| 72 20 64 72 65 67 20 64 | 2d 72 65 67 69 73 74 65 |r dreg d|-registe|
|00001b70| 72 73 29 20 0d 09 09 28 | 65 72 72 6f 72 20 22 49 |rs) ...(|error "I|
|00001b80| 6e 76 61 6c 69 64 20 64 | 61 74 61 20 72 65 67 69 |nvalid d|ata regi|
|00001b90| 73 74 65 72 2e 20 7e 25 | 49 6e 73 74 72 75 63 74 |ster. ~%|Instruct|
|00001ba0| 69 6f 6e 3a 20 6d 6f 76 | 65 71 20 20 4f 70 65 72 |ion: mov|eq Oper|
|00001bb0| 61 6e 64 3a 20 7e 41 22 | 20 64 72 65 67 29 29 0d |and: ~A"| dreg)).|
|00001bc0| 09 28 6c 69 73 74 20 28 | 2b 20 23 78 37 30 30 30 |.(list (|+ #x7000|
|00001bd0| 20 62 79 74 65 20 28 2a | 20 28 73 79 6d 62 6f 6c | byte (*| (symbol|
|00001be0| 2d 76 61 6c 75 65 20 64 | 72 65 67 29 20 23 78 32 |-value d|reg) #x2|
|00001bf0| 30 30 29 29 29 29 0d 0d | 28 64 65 66 6d 61 63 72 |00))))..|(defmacr|
|00001c00| 6f 20 6d 6f 76 65 2e 6c | 20 28 73 72 65 67 20 64 |o move.l| (sreg d|
|00001c10| 72 65 67 29 0d 09 28 6d | 6f 76 65 2d 69 6e 73 74 |reg)..(m|ove-inst|
|00001c20| 72 75 63 74 69 6f 6e 20 | 73 72 65 67 20 64 72 65 |ruction |sreg dre|
|00001c30| 67 20 27 6c 6f 6e 67 29 | 29 0d 0d 28 64 65 66 6d |g 'long)|)..(defm|
|00001c40| 61 63 72 6f 20 6d 6f 76 | 65 2e 62 20 28 73 72 65 |acro mov|e.b (sre|
|00001c50| 67 20 64 72 65 67 29 0d | 09 28 6d 6f 76 65 2d 69 |g dreg).|.(move-i|
|00001c60| 6e 73 74 72 75 63 74 69 | 6f 6e 20 73 72 65 67 20 |nstructi|on sreg |
|00001c70| 64 72 65 67 20 27 62 79 | 74 65 29 29 0d 0d 28 64 |dreg 'by|te))..(d|
|00001c80| 65 66 6d 61 63 72 6f 20 | 6d 6f 76 65 2e 77 20 28 |efmacro |move.w (|
|00001c90| 73 72 65 67 20 64 72 65 | 67 29 0d 09 28 6d 6f 76 |sreg dre|g)..(mov|
|00001ca0| 65 2d 69 6e 73 74 72 75 | 63 74 69 6f 6e 20 73 72 |e-instru|ction sr|
|00001cb0| 65 67 20 64 72 65 67 20 | 27 77 6f 72 64 29 29 0d |eg dreg |'word)).|
|00001cc0| 0d 28 64 65 66 75 6e 20 | 6d 6f 76 65 2d 69 6e 73 |.(defun |move-ins|
|00001cd0| 74 72 75 63 74 69 6f 6e | 20 28 73 72 65 67 20 64 |truction| (sreg d|
|00001ce0| 72 65 67 20 73 69 7a 65 | 29 0d 09 28 6c 65 74 20 |reg size|)..(let |
|00001cf0| 28 28 73 20 28 65 6e 63 | 6f 64 65 2d 61 64 64 72 |((s (enc|ode-addr|
|00001d00| 65 73 73 20 73 72 65 67 | 20 73 69 7a 65 29 29 28 |ess sreg| size))(|
|00001d10| 64 20 28 65 6e 63 6f 64 | 65 2d 61 64 64 72 65 73 |d (encod|e-addres|
|00001d20| 73 20 64 72 65 67 20 73 | 69 7a 65 29 29 20 6f 70 |s dreg s|ize)) op|
|00001d30| 2d 63 6f 64 65 29 0d 09 | 09 28 73 65 74 71 20 6f |-code)..|.(setq o|
|00001d40| 70 2d 63 6f 64 65 20 0d | 09 09 09 28 63 61 73 65 |p-code .|...(case|
|00001d50| 20 73 69 7a 65 0d 09 09 | 09 09 28 6c 6f 6e 67 20 | size...|..(long |
|00001d60| 23 78 32 30 30 30 29 0d | 09 09 09 09 28 62 79 74 |#x2000).|....(byt|
|00001d70| 65 20 23 78 31 30 30 30 | 29 0d 09 09 09 09 28 77 |e #x1000|).....(w|
|00001d80| 6f 72 64 20 23 78 33 30 | 30 30 29 29 29 0d 09 09 |ord #x30|00)))...|
|00001d90| 60 28 2c 28 2b 20 6f 70 | 2d 63 6f 64 65 20 0d 09 |`(,(+ op|-code ..|
|00001da0| 09 09 09 28 2a 20 28 65 | 6e 63 6f 64 65 64 2d 61 |...(* (e|ncoded-a|
|00001db0| 64 64 72 65 73 73 2d 72 | 65 67 20 64 29 20 23 78 |ddress-r|eg d) #x|
|00001dc0| 32 30 30 29 20 3b 20 64 | 65 73 74 69 6e 61 74 69 |200) ; d|estinati|
|00001dd0| 6f 6e 20 72 65 67 69 73 | 74 65 72 20 62 69 74 73 |on regis|ter bits|
|00001de0| 20 39 2d 31 31 0d 09 09 | 09 09 28 2a 20 28 65 6e | 9-11...|..(* (en|
|00001df0| 63 6f 64 65 64 2d 61 64 | 64 72 65 73 73 2d 6d 6f |coded-ad|dress-mo|
|00001e00| 64 65 20 64 29 20 23 78 | 34 30 29 20 3b 20 64 65 |de d) #x|40) ; de|
|00001e10| 73 74 69 6e 61 74 69 6f | 6e 20 6d 6f 64 65 20 62 |stinatio|n mode b|
|00001e20| 69 74 73 20 36 2d 38 0d | 09 09 09 09 28 2a 20 28 |its 6-8.|....(* (|
|00001e30| 65 6e 63 6f 64 65 64 2d | 61 64 64 72 65 73 73 2d |encoded-|address-|
|00001e40| 6d 6f 64 65 20 73 29 20 | 23 78 38 29 20 20 3b 20 |mode s) |#x8) ; |
|00001e50| 73 6f 75 72 63 65 20 6d | 6f 64 65 20 62 69 74 73 |source m|ode bits|
|00001e60| 20 33 2d 35 0d 09 09 09 | 09 28 65 6e 63 6f 64 65 | 3-5....|.(encode|
|00001e70| 64 2d 61 64 64 72 65 73 | 73 2d 72 65 67 20 73 29 |d-addres|s-reg s)|
|00001e80| 29 09 09 20 20 3b 20 73 | 6f 75 72 63 65 20 72 65 |).. ; s|ource re|
|00001e90| 67 69 73 74 65 72 0d 09 | 09 09 2c 40 28 65 6e 63 |gister..|..,@(enc|
|00001ea0| 6f 64 65 64 2d 61 64 64 | 72 65 73 73 2d 64 61 74 |oded-add|ress-dat|
|00001eb0| 61 20 73 29 0d 09 09 09 | 2c 40 28 65 6e 63 6f 64 |a s)....|,@(encod|
|00001ec0| 65 64 2d 61 64 64 72 65 | 73 73 2d 64 61 74 61 20 |ed-addre|ss-data |
|00001ed0| 64 29 29 29 29 0d 09 09 | 0d 09 09 09 0d 28 64 65 |d))))...|.....(de|
|00001ee0| 66 6d 61 63 72 6f 20 6d | 6f 76 65 61 2e 6c 20 28 |fmacro m|ovea.l (|
|00001ef0| 73 72 65 67 20 64 72 65 | 67 29 0d 09 28 75 6e 6c |sreg dre|g)..(unl|
|00001f00| 65 73 73 20 28 6d 65 6d | 62 65 72 20 64 72 65 67 |ess (mem|ber dreg|
|00001f10| 20 61 2d 72 65 67 69 73 | 74 65 72 73 29 20 0d 09 | a-regis|ters) ..|
|00001f20| 09 28 65 72 72 6f 72 20 | 22 49 6e 76 61 6c 69 64 |.(error |"Invalid|
|00001f30| 20 61 64 64 72 65 73 73 | 20 72 65 67 69 73 74 65 | address| registe|
|00001f40| 72 2e 20 7e 25 49 6e 73 | 74 72 75 63 74 69 6f 6e |r. ~%Ins|truction|
|00001f50| 3a 20 6d 6f 76 65 61 2e | 6c 20 20 4f 70 65 72 61 |: movea.|l Opera|
|00001f60| 6e 64 3a 20 7e 41 22 20 | 64 72 65 67 29 29 0d 09 |nd: ~A" |dreg))..|
|00001f70| 28 6c 65 74 20 28 28 73 | 20 28 65 6e 63 6f 64 65 |(let ((s| (encode|
|00001f80| 2d 61 64 64 72 65 73 73 | 20 73 72 65 67 29 29 28 |-address| sreg))(|
|00001f90| 64 20 28 73 79 6d 62 6f | 6c 2d 76 61 6c 75 65 20 |d (symbo|l-value |
|00001fa0| 64 72 65 67 29 29 29 0d | 09 09 28 61 70 70 65 6e |dreg))).|..(appen|
|00001fb0| 64 0d 09 09 09 28 6c 69 | 73 74 20 28 2b 20 23 78 |d....(li|st (+ #x|
|00001fc0| 32 30 34 30 20 0d 09 09 | 09 09 09 28 2a 20 64 20 |2040 ...|...(* d |
|00001fd0| 23 78 32 30 30 29 09 09 | 09 09 3b 20 64 65 73 74 |#x200)..|..; dest|
|00001fe0| 69 6e 61 74 69 6f 6e 20 | 72 65 67 69 73 74 65 72 |ination |register|
|00001ff0| 20 62 69 74 73 20 39 2d | 31 31 0d 09 09 09 09 09 | bits 9-|11......|
|00002000| 28 2a 20 28 65 6e 63 6f | 64 65 64 2d 61 64 64 72 |(* (enco|ded-addr|
|00002010| 65 73 73 2d 6d 6f 64 65 | 20 73 29 20 23 78 38 29 |ess-mode| s) #x8)|
|00002020| 20 3b 20 73 6f 75 72 63 | 65 20 6d 6f 64 65 20 62 | ; sourc|e mode b|
|00002030| 69 74 73 20 33 2d 35 0d | 09 09 09 09 09 28 65 6e |its 3-5.|.....(en|
|00002040| 63 6f 64 65 64 2d 61 64 | 64 72 65 73 73 2d 72 65 |coded-ad|dress-re|
|00002050| 67 20 73 29 29 29 09 09 | 20 3b 20 73 6f 75 72 63 |g s)))..| ; sourc|
|00002060| 65 20 72 65 67 69 73 74 | 65 72 0d 09 09 09 28 65 |e regist|er....(e|
|00002070| 6e 63 6f 64 65 64 2d 61 | 64 64 72 65 73 73 2d 64 |ncoded-a|ddress-d|
|00002080| 61 74 61 20 73 29 29 29 | 29 0d 0d 28 64 65 66 6d |ata s)))|)..(defm|
|00002090| 61 63 72 6f 20 61 64 64 | 2e 6c 20 28 73 72 63 20 |acro add|.l (src |
|000020a0| 64 65 73 74 29 0d 09 28 | 6c 65 74 20 28 28 73 20 |dest)..(|let ((s |
|000020b0| 28 65 6e 63 6f 64 65 2d | 61 64 64 72 65 73 73 20 |(encode-|address |
|000020c0| 73 72 63 29 29 28 64 20 | 28 65 6e 63 6f 64 65 2d |src))(d |(encode-|
|000020d0| 61 64 64 72 65 73 73 20 | 64 65 73 74 29 29 29 0d |address |dest))).|
|000020e0| 09 09 28 75 6e 6c 65 73 | 73 20 28 6f 72 20 28 3d |..(unles|s (or (=|
|000020f0| 20 28 65 6e 63 6f 64 65 | 64 2d 61 64 64 72 65 73 | (encode|d-addres|
|00002100| 73 2d 6d 6f 64 65 20 73 | 29 20 30 29 20 0d 09 09 |s-mode s|) 0) ...|
|00002110| 09 09 09 28 3d 20 28 65 | 6e 63 6f 64 65 64 2d 61 |...(= (e|ncoded-a|
|00002120| 64 64 72 65 73 73 2d 6d | 6f 64 65 20 64 29 20 30 |ddress-m|ode d) 0|
|00002130| 29 29 0d 09 09 09 28 65 | 72 72 6f 72 20 0d 09 09 |))....(e|rror ...|
|00002140| 09 09 22 54 68 65 20 73 | 6f 75 72 63 65 20 6f 72 |.."The s|ource or|
|00002150| 20 64 65 73 74 69 6e 61 | 74 69 6f 6e 20 6d 75 73 | destina|tion mus|
|00002160| 74 20 62 65 20 61 20 64 | 2d 72 65 67 69 73 74 65 |t be a d|-registe|
|00002170| 72 2e 20 7e 25 49 6e 73 | 74 72 75 63 74 69 6f 6e |r. ~%Ins|truction|
|00002180| 3a 20 61 64 64 2e 6c 20 | 20 4f 70 65 72 61 6e 64 |: add.l | Operand|
|00002190| 73 3a 20 7e 41 2c 20 7e | 41 22 20 73 72 63 20 64 |s: ~A, ~|A" src d|
|000021a0| 65 73 74 29 29 0d 09 09 | 28 69 66 20 28 3d 20 28 |est))...|(if (= (|
|000021b0| 65 6e 63 6f 64 65 64 2d | 61 64 64 72 65 73 73 2d |encoded-|address-|
|000021c0| 6d 6f 64 65 20 73 29 20 | 30 29 09 3b 20 69 66 20 |mode s) |0).; if |
|000021d0| 44 2d 72 65 67 69 73 74 | 65 72 20 69 73 20 73 6f |D-regist|er is so|
|000021e0| 75 72 63 65 0d 09 09 09 | 60 28 2c 28 2b 20 23 78 |urce....|`(,(+ #x|
|000021f0| 44 30 30 30 20 0d 09 09 | 09 09 28 2a 20 28 65 6e |D000 ...|..(* (en|
|00002200| 63 6f 64 65 64 2d 61 64 | 64 72 65 73 73 2d 72 65 |coded-ad|dress-re|
|00002210| 67 20 73 29 20 23 78 32 | 30 30 29 09 09 3b 20 73 |g s) #x2|00)..; s|
|00002220| 6f 75 72 63 65 20 72 65 | 67 69 73 74 65 72 20 62 |ource re|gister b|
|00002230| 69 74 73 20 39 2d 31 31 | 0d 09 09 09 09 28 2a 20 |its 9-11|.....(* |
|00002240| 36 20 23 78 34 30 29 09 | 09 09 09 09 09 09 09 3b |6 #x40).|.......;|
|00002250| 20 6f 70 2d 6d 6f 64 65 | 20 62 69 74 73 20 36 2d | op-mode| bits 6-|
|00002260| 38 0d 09 09 09 09 28 2a | 20 28 65 6e 63 6f 64 65 |8.....(*| (encode|
|00002270| 64 2d 61 64 64 72 65 73 | 73 2d 6d 6f 64 65 20 64 |d-addres|s-mode d|
|00002280| 29 20 23 78 38 29 09 09 | 3b 20 64 65 73 74 20 6d |) #x8)..|; dest m|
|00002290| 6f 64 65 20 62 69 74 73 | 20 33 2d 35 0d 09 09 09 |ode bits| 3-5....|
|000022a0| 09 28 65 6e 63 6f 64 65 | 64 2d 61 64 64 72 65 73 |.(encode|d-addres|
|000022b0| 73 2d 72 65 67 20 64 29 | 29 09 09 09 09 3b 20 64 |s-reg d)|)....; d|
|000022c0| 65 73 74 20 72 65 67 69 | 73 74 65 72 0d 09 09 09 |est regi|ster....|
|000022d0| 09 2c 40 28 65 6e 63 6f | 64 65 64 2d 61 64 64 72 |.,@(enco|ded-addr|
|000022e0| 65 73 73 2d 64 61 74 61 | 20 64 29 29 0d 09 09 09 |ess-data| d))....|
|000022f0| 09 09 09 09 09 09 09 3b | 20 65 6c 73 65 20 44 2d |.......;| else D-|
|00002300| 72 65 67 69 73 74 65 72 | 20 69 73 20 64 65 73 74 |register| is dest|
|00002310| 69 6e 61 74 69 6f 6e 0d | 09 09 09 60 28 2c 28 2b |ination.|...`(,(+|
|00002320| 20 23 78 44 30 30 30 20 | 0d 09 09 09 09 28 2a 20 | #xD000 |.....(* |
|00002330| 28 65 6e 63 6f 64 65 64 | 2d 61 64 64 72 65 73 73 |(encoded|-address|
|00002340| 2d 72 65 67 20 64 29 20 | 23 78 32 30 30 29 09 09 |-reg d) |#x200)..|
|00002350| 3b 20 64 65 73 74 20 72 | 65 67 69 73 74 65 72 20 |; dest r|egister |
|00002360| 62 69 74 73 20 39 2d 31 | 31 0d 09 09 09 09 28 2a |bits 9-1|1.....(*|
|00002370| 20 32 20 23 78 34 30 29 | 09 09 09 09 09 09 09 09 | 2 #x40)|........|
|00002380| 3b 20 6f 70 2d 6d 6f 64 | 65 20 62 69 74 73 20 36 |; op-mod|e bits 6|
|00002390| 2d 38 0d 09 09 09 09 28 | 2a 20 28 65 6e 63 6f 64 |-8.....(|* (encod|
|000023a0| 65 64 2d 61 64 64 72 65 | 73 73 2d 6d 6f 64 65 20 |ed-addre|ss-mode |
|000023b0| 73 29 20 23 78 38 29 09 | 09 3b 20 73 72 63 20 6d |s) #x8).|.; src m|
|000023c0| 6f 64 65 20 62 69 74 73 | 20 33 2d 35 0d 09 09 09 |ode bits| 3-5....|
|000023d0| 09 28 65 6e 63 6f 64 65 | 64 2d 61 64 64 72 65 73 |.(encode|d-addres|
|000023e0| 73 2d 72 65 67 20 73 29 | 29 09 09 09 09 3b 20 73 |s-reg s)|)....; s|
|000023f0| 72 63 20 72 65 67 69 73 | 74 65 72 0d 09 09 09 09 |rc regis|ter.....|
|00002400| 2c 40 28 65 6e 63 6f 64 | 65 64 2d 61 64 64 72 65 |,@(encod|ed-addre|
|00002410| 73 73 2d 64 61 74 61 20 | 73 29 29 29 29 29 0d 0d |ss-data |s)))))..|
|00002420| 28 64 65 66 6d 61 63 72 | 6f 20 61 64 64 69 2e 6c |(defmacr|o addi.l|
|00002430| 20 28 73 72 63 20 64 65 | 73 74 29 0d 09 28 69 6e | (src de|st)..(in|
|00002440| 63 66 20 2a 61 73 73 65 | 6d 62 6c 65 72 2d 6c 6f |cf *asse|mbler-lo|
|00002450| 63 61 6c 2d 61 64 64 72 | 65 73 73 2a 20 34 29 0d |cal-addr|ess* 4).|
|00002460| 09 28 6c 65 74 20 28 28 | 73 20 73 72 63 29 28 64 |.(let ((|s src)(d|
|00002470| 20 28 65 6e 63 6f 64 65 | 2d 61 64 64 72 65 73 73 | (encode|-address|
|00002480| 20 64 65 73 74 29 29 29 | 0d 09 09 28 75 6e 6c 65 | dest)))|...(unle|
|00002490| 73 73 20 28 69 6e 74 65 | 67 65 72 70 20 73 29 0d |ss (inte|gerp s).|
|000024a0| 09 09 09 28 65 72 72 6f | 72 20 22 54 68 65 20 73 |...(erro|r "The s|
|000024b0| 6f 75 72 63 65 20 6d 75 | 73 74 20 62 65 20 61 6e |ource mu|st be an|
|000024c0| 20 69 6e 74 65 67 65 72 | 2e 20 7e 25 49 6e 73 74 | integer|. ~%Inst|
|000024d0| 72 75 63 74 69 6f 6e 3a | 20 61 64 64 69 2e 6c 20 |ruction:| addi.l |
|000024e0| 20 4f 70 65 72 61 6e 64 | 3a 20 7e 41 22 20 73 29 | Operand|: ~A" s)|
|000024f0| 29 0d 09 09 60 28 2c 28 | 2b 20 23 78 30 36 38 30 |)...`(,(|+ #x0680|
|00002500| 20 0d 09 09 09 09 28 2a | 20 28 65 6e 63 6f 64 65 | .....(*| (encode|
|00002510| 64 2d 61 64 64 72 65 73 | 73 2d 6d 6f 64 65 20 64 |d-addres|s-mode d|
|00002520| 29 20 23 78 38 29 09 3b | 20 64 65 73 74 20 6d 6f |) #x8).;| dest mo|
|00002530| 64 65 20 62 69 74 73 20 | 33 2d 35 0d 09 09 09 09 |de bits |3-5.....|
|00002540| 28 65 6e 63 6f 64 65 64 | 2d 61 64 64 72 65 73 73 |(encoded|-address|
|00002550| 2d 72 65 67 20 64 29 29 | 09 09 09 3b 20 64 65 73 |-reg d))|...; des|
|00002560| 74 20 72 65 67 69 73 74 | 65 72 0d 09 09 09 09 2c |t regist|er.....,|
|00002570| 40 28 6d 75 6c 74 69 70 | 6c 65 2d 76 61 6c 75 65 |@(multip|le-value|
|00002580| 2d 6c 69 73 74 20 28 74 | 72 75 6e 63 61 74 65 20 |-list (t|runcate |
|00002590| 73 20 23 78 31 30 30 30 | 30 29 29 0d 09 09 09 09 |s #x1000|0)).....|
|000025a0| 2c 40 28 65 6e 63 6f 64 | 65 64 2d 61 64 64 72 65 |,@(encod|ed-addre|
|000025b0| 73 73 2d 64 61 74 61 20 | 64 29 29 29 29 0d 0d 28 |ss-data |d))))..(|
|000025c0| 64 65 66 6d 61 63 72 6f | 20 61 6e 64 2e 6c 20 28 |defmacro| and.l (|
|000025d0| 73 72 63 20 64 65 73 74 | 29 0d 09 28 6c 65 74 20 |src dest|)..(let |
|000025e0| 28 28 73 20 28 65 6e 63 | 6f 64 65 2d 61 64 64 72 |((s (enc|ode-addr|
|000025f0| 65 73 73 20 73 72 63 29 | 29 28 64 20 28 65 6e 63 |ess src)|)(d (enc|
|00002600| 6f 64 65 2d 61 64 64 72 | 65 73 73 20 64 65 73 74 |ode-addr|ess dest|
|00002610| 29 29 29 0d 09 09 28 75 | 6e 6c 65 73 73 20 28 6f |)))...(u|nless (o|
|00002620| 72 20 28 3d 20 28 65 6e | 63 6f 64 65 64 2d 61 64 |r (= (en|coded-ad|
|00002630| 64 72 65 73 73 2d 6d 6f | 64 65 20 73 29 20 30 29 |dress-mo|de s) 0)|
|00002640| 20 0d 09 09 09 09 09 28 | 3d 20 28 65 6e 63 6f 64 | ......(|= (encod|
|00002650| 65 64 2d 61 64 64 72 65 | 73 73 2d 6d 6f 64 65 20 |ed-addre|ss-mode |
|00002660| 64 29 20 30 29 29 0d 09 | 09 09 28 65 72 72 6f 72 |d) 0))..|..(error|
|00002670| 20 0d 09 09 09 09 22 54 | 68 65 20 73 6f 75 72 63 | ....."T|he sourc|
|00002680| 65 20 6f 72 20 64 65 73 | 74 69 6e 61 74 69 6f 6e |e or des|tination|
|00002690| 20 6d 75 73 74 20 62 65 | 20 61 20 64 2d 72 65 67 | must be| a d-reg|
|000026a0| 69 73 74 65 72 2e 20 7e | 25 49 6e 73 74 72 75 63 |ister. ~|%Instruc|
|000026b0| 74 69 6f 6e 3a 20 61 6e | 64 2e 6c 20 20 4f 70 65 |tion: an|d.l Ope|
|000026c0| 72 61 6e 64 73 3a 20 7e | 41 2c 20 7e 41 22 20 73 |rands: ~|A, ~A" s|
|000026d0| 72 63 20 64 65 73 74 29 | 29 0d 09 09 28 69 66 20 |rc dest)|)...(if |
|000026e0| 28 6f 72 20 28 3d 20 28 | 65 6e 63 6f 64 65 64 2d |(or (= (|encoded-|
|000026f0| 61 64 64 72 65 73 73 2d | 6d 6f 64 65 20 73 29 20 |address-|mode s) |
|00002700| 31 29 20 0d 09 09 09 09 | 28 3d 20 28 65 6e 63 6f |1) .....|(= (enco|
|00002710| 64 65 64 2d 61 64 64 72 | 65 73 73 2d 6d 6f 64 65 |ded-addr|ess-mode|
|00002720| 20 64 29 20 31 29 29 0d | 09 09 09 28 65 72 72 6f | d) 1)).|...(erro|
|00002730| 72 20 0d 09 09 09 09 22 | 41 2d 72 65 67 69 73 74 |r ....."|A-regist|
|00002740| 65 72 20 6e 6f 74 20 61 | 6c 6c 6f 77 65 64 20 61 |er not a|llowed a|
|00002750| 73 20 6f 70 65 72 61 6e | 64 2e 20 7e 25 49 6e 73 |s operan|d. ~%Ins|
|00002760| 74 72 75 63 74 69 6f 6e | 3a 20 61 6e 64 2e 6c 20 |truction|: and.l |
|00002770| 20 4f 70 65 72 61 6e 64 | 73 3a 20 7e 41 2c 20 7e | Operand|s: ~A, ~|
|00002780| 41 22 20 73 72 63 20 64 | 65 73 74 29 29 0d 09 09 |A" src d|est))...|
|00002790| 28 69 66 20 28 3d 20 28 | 65 6e 63 6f 64 65 64 2d |(if (= (|encoded-|
|000027a0| 61 64 64 72 65 73 73 2d | 6d 6f 64 65 20 73 29 20 |address-|mode s) |
|000027b0| 30 29 3b 20 69 66 20 44 | 2d 72 65 67 69 73 74 65 |0); if D|-registe|
|000027c0| 72 20 69 73 20 73 6f 75 | 72 63 65 0d 09 09 09 60 |r is sou|rce....`|
|000027d0| 28 2c 28 2b 20 23 78 43 | 30 30 30 20 0d 09 09 09 |(,(+ #xC|000 ....|
|000027e0| 09 28 2a 20 28 65 6e 63 | 6f 64 65 64 2d 61 64 64 |.(* (enc|oded-add|
|000027f0| 72 65 73 73 2d 72 65 67 | 20 73 29 20 23 78 32 30 |ress-reg| s) #x20|
|00002800| 30 29 20 3b 20 73 6f 75 | 72 63 65 20 72 65 67 69 |0) ; sou|rce regi|
|00002810| 73 74 65 72 20 62 69 74 | 73 20 39 2d 31 31 0d 09 |ster bit|s 9-11..|
|00002820| 09 09 09 28 2a 20 36 20 | 23 78 34 30 29 09 09 09 |...(* 6 |#x40)...|
|00002830| 09 09 09 3b 20 6f 70 2d | 6d 6f 64 65 20 62 69 74 |...; op-|mode bit|
|00002840| 73 20 36 2d 38 0d 09 09 | 09 09 28 2a 20 28 65 6e |s 6-8...|..(* (en|
|00002850| 63 6f 64 65 64 2d 61 64 | 64 72 65 73 73 2d 6d 6f |coded-ad|dress-mo|
|00002860| 64 65 20 64 29 20 23 78 | 38 29 3b 20 64 65 73 74 |de d) #x|8); dest|
|00002870| 20 6d 6f 64 65 20 62 69 | 74 73 20 33 2d 35 0d 09 | mode bi|ts 3-5..|
|00002880| 09 09 09 28 65 6e 63 6f | 64 65 64 2d 61 64 64 72 |...(enco|ded-addr|
|00002890| 65 73 73 2d 72 65 67 20 | 64 29 29 09 09 3b 20 64 |ess-reg |d))..; d|
|000028a0| 65 73 74 20 72 65 67 69 | 73 74 65 72 0d 09 09 09 |est regi|ster....|
|000028b0| 09 2c 40 28 65 6e 63 6f | 64 65 64 2d 61 64 64 72 |.,@(enco|ded-addr|
|000028c0| 65 73 73 2d 64 61 74 61 | 20 64 29 29 0d 09 09 09 |ess-data| d))....|
|000028d0| 09 09 09 09 09 09 09 3b | 20 65 6c 73 65 20 44 2d |.......;| else D-|
|000028e0| 72 65 67 69 73 74 65 72 | 20 69 73 20 64 65 73 74 |register| is dest|
|000028f0| 69 6e 61 74 69 6f 6e 0d | 09 09 09 60 28 2c 28 2b |ination.|...`(,(+|
|00002900| 20 23 78 43 30 30 30 20 | 0d 09 09 09 09 28 2a 20 | #xC000 |.....(* |
|00002910| 28 65 6e 63 6f 64 65 64 | 2d 61 64 64 72 65 73 73 |(encoded|-address|
|00002920| 2d 72 65 67 20 64 29 20 | 23 78 32 30 30 29 3b 20 |-reg d) |#x200); |
|00002930| 64 65 73 74 20 72 65 67 | 69 73 74 65 72 20 62 69 |dest reg|ister bi|
|00002940| 74 73 20 39 2d 31 31 0d | 09 09 09 09 28 2a 20 32 |ts 9-11.|....(* 2|
|00002950| 20 23 78 34 30 29 09 09 | 09 09 09 09 3b 20 6f 70 | #x40)..|....; op|
|00002960| 2d 6d 6f 64 65 20 62 69 | 74 73 20 36 2d 38 0d 09 |-mode bi|ts 6-8..|
|00002970| 09 09 09 28 2a 20 28 65 | 6e 63 6f 64 65 64 2d 61 |...(* (e|ncoded-a|
|00002980| 64 64 72 65 73 73 2d 6d | 6f 64 65 20 73 29 20 23 |ddress-m|ode s) #|
|00002990| 78 38 29 3b 20 73 72 63 | 20 6d 6f 64 65 20 62 69 |x8); src| mode bi|
|000029a0| 74 73 20 33 2d 35 0d 09 | 09 09 09 28 65 6e 63 6f |ts 3-5..|...(enco|
|000029b0| 64 65 64 2d 61 64 64 72 | 65 73 73 2d 72 65 67 20 |ded-addr|ess-reg |
|000029c0| 73 29 29 09 09 3b 20 73 | 72 63 20 72 65 67 69 73 |s))..; s|rc regis|
|000029d0| 74 65 72 0d 09 09 09 09 | 2c 40 28 65 6e 63 6f 64 |ter.....|,@(encod|
|000029e0| 65 64 2d 61 64 64 72 65 | 73 73 2d 64 61 74 61 20 |ed-addre|ss-data |
|000029f0| 73 29 29 29 29 29 0d 0d | 28 64 65 66 6d 61 63 72 |s)))))..|(defmacr|
|00002a00| 6f 20 61 6e 64 69 2e 6c | 20 28 73 72 63 20 64 65 |o andi.l| (src de|
|00002a10| 73 74 29 0d 09 28 69 6e | 63 66 20 2a 61 73 73 65 |st)..(in|cf *asse|
|00002a20| 6d 62 6c 65 72 2d 6c 6f | 63 61 6c 2d 61 64 64 72 |mbler-lo|cal-addr|
|00002a30| 65 73 73 2a 20 34 29 0d | 09 28 6c 65 74 20 28 28 |ess* 4).|.(let ((|
|00002a40| 73 20 73 72 63 29 28 64 | 20 28 65 6e 63 6f 64 65 |s src)(d| (encode|
|00002a50| 2d 61 64 64 72 65 73 73 | 20 64 65 73 74 29 29 29 |-address| dest)))|
|00002a60| 0d 09 09 28 75 6e 6c 65 | 73 73 20 28 69 6e 74 65 |...(unle|ss (inte|
|00002a70| 67 65 72 70 20 73 29 0d | 09 09 09 28 65 72 72 6f |gerp s).|...(erro|
|00002a80| 72 20 22 54 68 65 20 73 | 6f 75 72 63 65 20 6d 75 |r "The s|ource mu|
|00002a90| 73 74 20 62 65 20 61 6e | 20 69 6e 74 65 67 65 72 |st be an| integer|
|00002aa0| 2e 20 7e 25 49 6e 73 74 | 72 75 63 74 69 6f 6e 3a |. ~%Inst|ruction:|
|00002ab0| 20 61 6e 64 69 2e 6c 20 | 20 4f 70 65 72 61 6e 64 | andi.l | Operand|
|00002ac0| 3a 20 7e 41 22 20 73 72 | 63 29 29 0d 09 09 28 69 |: ~A" sr|c))...(i|
|00002ad0| 66 20 28 3d 20 28 65 6e | 63 6f 64 65 64 2d 61 64 |f (= (en|coded-ad|
|00002ae0| 64 72 65 73 73 2d 6d 6f | 64 65 20 64 29 20 31 29 |dress-mo|de d) 1)|
|00002af0| 0d 09 09 09 28 65 72 72 | 6f 72 20 22 41 2d 72 65 |....(err|or "A-re|
|00002b00| 67 69 73 74 65 72 20 6e | 6f 74 20 61 6c 6c 6f 77 |gister n|ot allow|
|00002b10| 65 64 20 61 73 20 64 65 | 73 74 69 6e 61 74 69 6f |ed as de|stinatio|
|00002b20| 6e 2e 20 7e 25 49 6e 73 | 74 72 75 63 74 69 6f 6e |n. ~%Ins|truction|
|00002b30| 3a 20 61 6e 64 69 2e 6c | 20 20 4f 70 65 72 61 6e |: andi.l| Operan|
|00002b40| 64 3a 20 7e 41 22 20 64 | 65 73 74 29 29 0d 09 09 |d: ~A" d|est))...|
|00002b50| 60 28 2c 28 2b 20 23 78 | 30 32 38 30 20 0d 09 09 |`(,(+ #x|0280 ...|
|00002b60| 09 09 28 2a 20 28 65 6e | 63 6f 64 65 64 2d 61 64 |..(* (en|coded-ad|
|00002b70| 64 72 65 73 73 2d 6d 6f | 64 65 20 64 29 20 23 78 |dress-mo|de d) #x|
|00002b80| 38 29 3b 20 64 65 73 74 | 20 6d 6f 64 65 20 62 69 |8); dest| mode bi|
|00002b90| 74 73 20 33 2d 35 0d 09 | 09 09 09 28 65 6e 63 6f |ts 3-5..|...(enco|
|00002ba0| 64 65 64 2d 61 64 64 72 | 65 73 73 2d 72 65 67 20 |ded-addr|ess-reg |
|00002bb0| 64 29 29 09 09 3b 20 64 | 65 73 74 20 72 65 67 69 |d))..; d|est regi|
|00002bc0| 73 74 65 72 0d 09 09 09 | 09 2c 40 28 6d 75 6c 74 |ster....|.,@(mult|
|00002bd0| 69 70 6c 65 2d 76 61 6c | 75 65 2d 6c 69 73 74 20 |iple-val|ue-list |
|00002be0| 28 74 72 75 6e 63 61 74 | 65 20 73 20 23 78 31 30 |(truncat|e s #x10|
|00002bf0| 30 30 30 29 29 0d 09 09 | 09 09 2c 40 28 65 6e 63 |000))...|..,@(enc|
|00002c00| 6f 64 65 64 2d 61 64 64 | 72 65 73 73 2d 64 61 74 |oded-add|ress-dat|
|00002c10| 61 20 64 29 29 29 29 0d | 0d 28 64 65 66 6d 61 63 |a d)))).|.(defmac|
|00002c20| 72 6f 20 6f 72 2e 6c 20 | 28 73 72 63 20 64 65 73 |ro or.l |(src des|
|00002c30| 74 29 0d 09 28 6c 65 74 | 20 28 28 73 20 28 65 6e |t)..(let| ((s (en|
|00002c40| 63 6f 64 65 2d 61 64 64 | 72 65 73 73 20 73 72 63 |code-add|ress src|
|00002c50| 29 29 28 64 20 28 65 6e | 63 6f 64 65 2d 61 64 64 |))(d (en|code-add|
|00002c60| 72 65 73 73 20 64 65 73 | 74 29 29 29 0d 09 09 28 |ress des|t)))...(|
|00002c70| 75 6e 6c 65 73 73 20 28 | 6f 72 20 28 3d 20 28 65 |unless (|or (= (e|
|00002c80| 6e 63 6f 64 65 64 2d 61 | 64 64 72 65 73 73 2d 6d |ncoded-a|ddress-m|
|00002c90| 6f 64 65 20 73 29 20 30 | 29 20 0d 09 09 09 09 09 |ode s) 0|) ......|
|00002ca0| 28 3d 20 28 65 6e 63 6f | 64 65 64 2d 61 64 64 72 |(= (enco|ded-addr|
|00002cb0| 65 73 73 2d 6d 6f 64 65 | 20 64 29 20 30 29 29 0d |ess-mode| d) 0)).|
|00002cc0| 09 09 09 28 65 72 72 6f | 72 20 0d 09 09 09 09 22 |...(erro|r ....."|
|00002cd0| 54 68 65 20 73 6f 75 72 | 63 65 20 6f 72 20 64 65 |The sour|ce or de|
|00002ce0| 73 74 69 6e 61 74 69 6f | 6e 20 6d 75 73 74 20 62 |stinatio|n must b|
|00002cf0| 65 20 61 20 64 2d 72 65 | 67 69 73 74 65 72 2e 20 |e a d-re|gister. |
|00002d00| 7e 25 49 6e 73 74 72 75 | 63 74 69 6f 6e 3a 20 6f |~%Instru|ction: o|
|00002d10| 72 2e 6c 20 20 4f 70 65 | 72 61 6e 64 73 3a 20 7e |r.l Ope|rands: ~|
|00002d20| 41 2c 20 7e 41 22 20 73 | 72 63 20 64 65 73 74 29 |A, ~A" s|rc dest)|
|00002d30| 29 0d 09 09 28 69 66 20 | 28 6f 72 20 28 3d 20 28 |)...(if |(or (= (|
|00002d40| 65 6e 63 6f 64 65 64 2d | 61 64 64 72 65 73 73 2d |encoded-|address-|
|00002d50| 6d 6f 64 65 20 73 29 20 | 31 29 20 0d 09 09 09 09 |mode s) |1) .....|
|00002d60| 28 3d 20 28 65 6e 63 6f | 64 65 64 2d 61 64 64 72 |(= (enco|ded-addr|
|00002d70| 65 73 73 2d 6d 6f 64 65 | 20 64 29 20 31 29 29 0d |ess-mode| d) 1)).|
|00002d80| 09 09 09 28 65 72 72 6f | 72 20 0d 09 09 09 09 22 |...(erro|r ....."|
|00002d90| 41 2d 72 65 67 69 73 74 | 65 72 20 6e 6f 74 20 61 |A-regist|er not a|
|00002da0| 6c 6c 6f 77 65 64 20 61 | 73 20 6f 70 65 72 61 6e |llowed a|s operan|
|00002db0| 64 2e 20 7e 25 49 6e 73 | 74 72 75 63 74 69 6f 6e |d. ~%Ins|truction|
|00002dc0| 3a 20 6f 72 2e 6c 20 20 | 4f 70 65 72 61 6e 64 73 |: or.l |Operands|
|00002dd0| 3a 20 7e 41 2c 20 7e 41 | 22 20 73 72 63 20 64 65 |: ~A, ~A|" src de|
|00002de0| 73 74 29 29 0d 09 09 28 | 69 66 20 28 3d 20 28 65 |st))...(|if (= (e|
|00002df0| 6e 63 6f 64 65 64 2d 61 | 64 64 72 65 73 73 2d 6d |ncoded-a|ddress-m|
|00002e00| 6f 64 65 20 73 29 20 30 | 29 09 09 3b 20 69 66 20 |ode s) 0|)..; if |
|00002e10| 44 2d 72 65 67 69 73 74 | 65 72 20 69 73 20 73 6f |D-regist|er is so|
|00002e20| 75 72 63 65 0d 09 09 09 | 60 28 2c 28 2b 20 23 78 |urce....|`(,(+ #x|
|00002e30| 38 30 30 30 20 0d 09 09 | 09 09 28 2a 20 28 65 6e |8000 ...|..(* (en|
|00002e40| 63 6f 64 65 64 2d 61 64 | 64 72 65 73 73 2d 72 65 |coded-ad|dress-re|
|00002e50| 67 20 73 29 20 23 78 32 | 30 30 29 3b 20 73 6f 75 |g s) #x2|00); sou|
|00002e60| 72 63 65 20 72 65 67 69 | 73 74 65 72 20 62 69 74 |rce regi|ster bit|
|00002e70| 73 20 39 2d 31 31 0d 09 | 09 09 09 28 2a 20 36 20 |s 9-11..|...(* 6 |
|00002e80| 23 78 34 30 29 09 09 09 | 09 09 09 3b 20 6f 70 2d |#x40)...|...; op-|
|00002e90| 6d 6f 64 65 20 62 69 74 | 73 20 36 2d 38 0d 09 09 |mode bit|s 6-8...|
|00002ea0| 09 09 28 2a 20 28 65 6e | 63 6f 64 65 64 2d 61 64 |..(* (en|coded-ad|
|00002eb0| 64 72 65 73 73 2d 6d 6f | 64 65 20 64 29 20 23 78 |dress-mo|de d) #x|
|00002ec0| 38 29 3b 20 64 65 73 74 | 20 6d 6f 64 65 20 62 69 |8); dest| mode bi|
|00002ed0| 74 73 20 33 2d 35 0d 09 | 09 09 09 28 65 6e 63 6f |ts 3-5..|...(enco|
|00002ee0| 64 65 64 2d 61 64 64 72 | 65 73 73 2d 72 65 67 20 |ded-addr|ess-reg |
|00002ef0| 64 29 29 09 09 3b 20 64 | 65 73 74 20 72 65 67 69 |d))..; d|est regi|
|00002f00| 73 74 65 72 0d 09 09 09 | 09 2c 40 28 65 6e 63 6f |ster....|.,@(enco|
|00002f10| 64 65 64 2d 61 64 64 72 | 65 73 73 2d 64 61 74 61 |ded-addr|ess-data|
|00002f20| 20 64 29 29 0d 09 09 09 | 09 09 09 09 09 09 09 3b | d))....|.......;|
|00002f30| 20 65 6c 73 65 20 44 2d | 72 65 67 69 73 74 65 72 | else D-|register|
|00002f40| 20 69 73 20 64 65 73 74 | 69 6e 61 74 69 6f 6e 0d | is dest|ination.|
|00002f50| 09 09 09 60 28 2c 28 2b | 20 23 78 38 30 30 30 20 |...`(,(+| #x8000 |
|00002f60| 0d 09 09 09 09 28 2a 20 | 28 65 6e 63 6f 64 65 64 |.....(* |(encoded|
|00002f70| 2d 61 64 64 72 65 73 73 | 2d 72 65 67 20 64 29 20 |-address|-reg d) |
|00002f80| 23 78 32 30 30 29 3b 20 | 64 65 73 74 20 72 65 67 |#x200); |dest reg|
|00002f90| 69 73 74 65 72 20 62 69 | 74 73 20 39 2d 31 31 0d |ister bi|ts 9-11.|
|00002fa0| 09 09 09 09 28 2a 20 32 | 20 23 78 34 30 29 09 09 |....(* 2| #x40)..|
|00002fb0| 09 09 09 09 3b 20 6f 70 | 2d 6d 6f 64 65 20 62 69 |....; op|-mode bi|
|00002fc0| 74 73 20 36 2d 38 0d 09 | 09 09 09 28 2a 20 28 65 |ts 6-8..|...(* (e|
|00002fd0| 6e 63 6f 64 65 64 2d 61 | 64 64 72 65 73 73 2d 6d |ncoded-a|ddress-m|
|00002fe0| 6f 64 65 20 73 29 20 23 | 78 38 29 3b 20 73 72 63 |ode s) #|x8); src|
|00002ff0| 20 6d 6f 64 65 20 62 69 | 74 73 20 33 2d 35 0d 09 | mode bi|ts 3-5..|
|00003000| 09 09 09 28 65 6e 63 6f | 64 65 64 2d 61 64 64 72 |...(enco|ded-addr|
|00003010| 65 73 73 2d 72 65 67 20 | 73 29 29 09 09 3b 20 73 |ess-reg |s))..; s|
|00003020| 72 63 20 72 65 67 69 73 | 74 65 72 0d 09 09 09 09 |rc regis|ter.....|
|00003030| 2c 40 28 65 6e 63 6f 64 | 65 64 2d 61 64 64 72 65 |,@(encod|ed-addre|
|00003040| 73 73 2d 64 61 74 61 20 | 73 29 29 29 29 29 0d 0d |ss-data |s)))))..|
|00003050| 28 64 65 66 6d 61 63 72 | 6f 20 6f 72 69 2e 6c 20 |(defmacr|o ori.l |
|00003060| 28 73 72 63 20 64 65 73 | 74 29 0d 09 28 69 6e 63 |(src des|t)..(inc|
|00003070| 66 20 2a 61 73 73 65 6d | 62 6c 65 72 2d 6c 6f 63 |f *assem|bler-loc|
|00003080| 61 6c 2d 61 64 64 72 65 | 73 73 2a 20 34 29 0d 09 |al-addre|ss* 4)..|
|00003090| 28 6c 65 74 20 28 28 73 | 20 73 72 63 29 28 64 20 |(let ((s| src)(d |
|000030a0| 28 65 6e 63 6f 64 65 2d | 61 64 64 72 65 73 73 20 |(encode-|address |
|000030b0| 64 65 73 74 29 29 29 0d | 09 09 28 75 6e 6c 65 73 |dest))).|..(unles|
|000030c0| 73 20 28 69 6e 74 65 67 | 65 72 70 20 73 29 0d 09 |s (integ|erp s)..|
|000030d0| 09 09 28 65 72 72 6f 72 | 20 22 54 68 65 20 73 6f |..(error| "The so|
|000030e0| 75 72 63 65 20 6f 66 20 | 27 6f 72 69 27 20 6d 75 |urce of |'ori' mu|
|000030f0| 73 74 20 62 65 20 61 6e | 20 69 6e 74 65 67 65 72 |st be an| integer|
|00003100| 22 29 29 0d 09 09 28 69 | 66 20 28 3d 20 28 65 6e |"))...(i|f (= (en|
|00003110| 63 6f 64 65 64 2d 61 64 | 64 72 65 73 73 2d 6d 6f |coded-ad|dress-mo|
|00003120| 64 65 20 64 29 20 31 29 | 0d 09 09 09 28 65 72 72 |de d) 1)|....(err|
|00003130| 6f 72 20 22 6f 72 69 3a | 20 64 65 73 74 69 6e 61 |or "ori:| destina|
|00003140| 74 69 6f 6e 20 63 61 6e | 6e 6f 74 20 62 65 20 61 |tion can|not be a|
|00003150| 6e 20 61 2d 72 65 67 69 | 73 74 65 72 22 29 29 0d |n a-regi|ster")).|
|00003160| 09 09 60 28 2c 28 2b 20 | 23 78 30 30 38 30 20 0d |..`(,(+ |#x0080 .|
|00003170| 09 09 09 09 28 2a 20 28 | 65 6e 63 6f 64 65 64 2d |....(* (|encoded-|
|00003180| 61 64 64 72 65 73 73 2d | 6d 6f 64 65 20 64 29 20 |address-|mode d) |
|00003190| 23 78 38 29 3b 20 64 65 | 73 74 20 6d 6f 64 65 20 |#x8); de|st mode |
|000031a0| 62 69 74 73 20 33 2d 35 | 0d 09 09 09 09 28 65 6e |bits 3-5|.....(en|
|000031b0| 63 6f 64 65 64 2d 61 64 | 64 72 65 73 73 2d 72 65 |coded-ad|dress-re|
|000031c0| 67 20 64 29 29 09 09 3b | 20 64 65 73 74 20 72 65 |g d))..;| dest re|
|000031d0| 67 69 73 74 65 72 0d 09 | 09 09 09 2c 40 28 6d 75 |gister..|...,@(mu|
|000031e0| 6c 74 69 70 6c 65 2d 76 | 61 6c 75 65 2d 6c 69 73 |ltiple-v|alue-lis|
|000031f0| 74 20 28 74 72 75 6e 63 | 61 74 65 20 73 20 23 78 |t (trunc|ate s #x|
|00003200| 31 30 30 30 30 29 29 0d | 09 09 09 09 2c 40 28 65 |10000)).|....,@(e|
|00003210| 6e 63 6f 64 65 64 2d 61 | 64 64 72 65 73 73 2d 64 |ncoded-a|ddress-d|
|00003220| 61 74 61 20 64 29 29 29 | 29 0d 0d 28 64 65 66 6d |ata d)))|)..(defm|
|00003230| 61 63 72 6f 20 65 6f 72 | 2e 6c 20 28 73 72 63 20 |acro eor|.l (src |
|00003240| 64 65 73 74 29 0d 09 28 | 6c 65 74 20 28 28 73 20 |dest)..(|let ((s |
|00003250| 28 65 6e 63 6f 64 65 2d | 61 64 64 72 65 73 73 20 |(encode-|address |
|00003260| 73 72 63 29 29 28 64 20 | 28 65 6e 63 6f 64 65 2d |src))(d |(encode-|
|00003270| 61 64 64 72 65 73 73 20 | 64 65 73 74 29 29 29 0d |address |dest))).|
|00003280| 09 09 28 75 6e 6c 65 73 | 73 20 28 3d 20 28 65 6e |..(unles|s (= (en|
|00003290| 63 6f 64 65 64 2d 61 64 | 64 72 65 73 73 2d 6d 6f |coded-ad|dress-mo|
|000032a0| 64 65 20 73 29 20 30 29 | 0d 09 09 09 28 65 72 72 |de s) 0)|....(err|
|000032b0| 6f 72 20 22 65 6f 72 3a | 20 73 6f 75 72 63 65 20 |or "eor:| source |
|000032c0| 6d 75 73 74 20 62 65 20 | 61 20 64 2d 72 65 67 69 |must be |a d-regi|
|000032d0| 73 74 65 72 22 29 29 0d | 09 09 28 69 66 20 28 3d |ster")).|..(if (=|
|000032e0| 20 28 65 6e 63 6f 64 65 | 64 2d 61 64 64 72 65 73 | (encode|d-addres|
|000032f0| 73 2d 6d 6f 64 65 20 64 | 29 20 31 29 0d 09 09 09 |s-mode d|) 1)....|
|00003300| 28 65 72 72 6f 72 20 22 | 65 6f 72 3a 20 64 65 73 |(error "|eor: des|
|00003310| 74 69 6e 61 74 69 6f 6e | 20 63 61 6e 6e 6f 74 20 |tination| cannot |
|00003320| 62 65 20 61 6e 20 61 2d | 72 65 67 69 73 74 65 72 |be an a-|register|
|00003330| 22 29 29 0d 09 09 60 28 | 2c 28 2b 20 23 78 42 30 |"))...`(|,(+ #xB0|
|00003340| 30 30 20 0d 09 09 09 28 | 2a 20 28 65 6e 63 6f 64 |00 ....(|* (encod|
|00003350| 65 64 2d 61 64 64 72 65 | 73 73 2d 72 65 67 20 73 |ed-addre|ss-reg s|
|00003360| 29 20 23 78 32 30 30 29 | 3b 20 73 6f 75 72 63 65 |) #x200)|; source|
|00003370| 20 72 65 67 69 73 74 65 | 72 20 62 69 74 73 20 39 | registe|r bits 9|
|00003380| 2d 31 31 0d 09 09 09 28 | 2a 20 36 20 23 78 34 30 |-11....(|* 6 #x40|
|00003390| 29 09 09 09 09 09 09 3b | 20 6f 70 2d 6d 6f 64 65 |)......;| op-mode|
|000033a0| 20 62 69 74 73 20 36 2d | 38 0d 09 09 09 28 2a 20 | bits 6-|8....(* |
|000033b0| 28 65 6e 63 6f 64 65 64 | 2d 61 64 64 72 65 73 73 |(encoded|-address|
|000033c0| 2d 6d 6f 64 65 20 64 29 | 20 23 78 38 29 3b 20 64 |-mode d)| #x8); d|
|000033d0| 65 73 74 20 6d 6f 64 65 | 20 62 69 74 73 20 33 2d |est mode| bits 3-|
|000033e0| 35 0d 09 09 09 28 65 6e | 63 6f 64 65 64 2d 61 64 |5....(en|coded-ad|
|000033f0| 64 72 65 73 73 2d 72 65 | 67 20 64 29 29 09 09 3b |dress-re|g d))..;|
|00003400| 20 64 65 73 74 20 72 65 | 67 69 73 74 65 72 0d 09 | dest re|gister..|
|00003410| 09 09 2c 40 28 65 6e 63 | 6f 64 65 64 2d 61 64 64 |..,@(enc|oded-add|
|00003420| 72 65 73 73 2d 64 61 74 | 61 20 64 29 29 29 29 0d |ress-dat|a d)))).|
|00003430| 0d 28 64 65 66 6d 61 63 | 72 6f 20 65 6f 72 69 2e |.(defmac|ro eori.|
|00003440| 6c 20 28 73 72 63 20 64 | 65 73 74 29 0d 09 28 69 |l (src d|est)..(i|
|00003450| 6e 63 66 20 2a 61 73 73 | 65 6d 62 6c 65 72 2d 6c |ncf *ass|embler-l|
|00003460| 6f 63 61 6c 2d 61 64 64 | 72 65 73 73 2a 20 34 29 |ocal-add|ress* 4)|
|00003470| 0d 09 28 6c 65 74 20 28 | 28 73 20 73 72 63 29 28 |..(let (|(s src)(|
|00003480| 64 20 28 65 6e 63 6f 64 | 65 2d 61 64 64 72 65 73 |d (encod|e-addres|
|00003490| 73 20 64 65 73 74 29 29 | 29 0d 09 09 28 75 6e 6c |s dest))|)...(unl|
|000034a0| 65 73 73 20 28 69 6e 74 | 65 67 65 72 70 20 73 29 |ess (int|egerp s)|
|000034b0| 0d 09 09 09 28 65 72 72 | 6f 72 20 22 54 68 65 20 |....(err|or "The |
|000034c0| 73 6f 75 72 63 65 20 6f | 66 20 27 65 6f 72 69 27 |source o|f 'eori'|
|000034d0| 20 6d 75 73 74 20 62 65 | 20 61 6e 20 69 6e 74 65 | must be| an inte|
|000034e0| 67 65 72 22 29 29 0d 09 | 09 28 69 66 20 28 3d 20 |ger"))..|.(if (= |
|000034f0| 28 65 6e 63 6f 64 65 64 | 2d 61 64 64 72 65 73 73 |(encoded|-address|
|00003500| 2d 6d 6f 64 65 20 64 29 | 20 31 29 0d 09 09 09 28 |-mode d)| 1)....(|
|00003510| 65 72 72 6f 72 20 22 65 | 6f 72 2e 69 3a 20 64 65 |error "e|or.i: de|
|00003520| 73 74 69 6e 61 74 69 6f | 6e 20 63 61 6e 6e 6f 74 |stinatio|n cannot|
|00003530| 20 62 65 20 61 6e 20 61 | 2d 72 65 67 69 73 74 65 | be an a|-registe|
|00003540| 72 22 29 29 0d 09 09 60 | 28 2c 28 2b 20 23 78 30 |r"))...`|(,(+ #x0|
|00003550| 41 38 30 20 0d 09 09 09 | 09 28 2a 20 28 65 6e 63 |A80 ....|.(* (enc|
|00003560| 6f 64 65 64 2d 61 64 64 | 72 65 73 73 2d 6d 6f 64 |oded-add|ress-mod|
|00003570| 65 20 64 29 20 23 78 38 | 29 3b 20 64 65 73 74 20 |e d) #x8|); dest |
|00003580| 6d 6f 64 65 20 62 69 74 | 73 20 33 2d 35 0d 09 09 |mode bit|s 3-5...|
|00003590| 09 09 28 65 6e 63 6f 64 | 65 64 2d 61 64 64 72 65 |..(encod|ed-addre|
|000035a0| 73 73 2d 72 65 67 20 64 | 29 29 09 09 3b 20 64 65 |ss-reg d|))..; de|
|000035b0| 73 74 20 72 65 67 69 73 | 74 65 72 0d 09 09 09 09 |st regis|ter.....|
|000035c0| 2c 40 28 6d 75 6c 74 69 | 70 6c 65 2d 76 61 6c 75 |,@(multi|ple-valu|
|000035d0| 65 2d 6c 69 73 74 20 28 | 74 72 75 6e 63 61 74 65 |e-list (|truncate|
|000035e0| 20 73 20 23 78 31 30 30 | 30 30 29 29 0d 09 09 09 | s #x100|00))....|
|000035f0| 09 2c 40 28 65 6e 63 6f | 64 65 64 2d 61 64 64 72 |.,@(enco|ded-addr|
|00003600| 65 73 73 2d 64 61 74 61 | 20 64 29 29 29 29 0d 0d |ess-data| d))))..|
|00003610| 28 64 65 66 6d 61 63 72 | 6f 20 73 75 62 2e 6c 20 |(defmacr|o sub.l |
|00003620| 28 73 72 63 20 64 65 73 | 74 29 0d 09 28 6c 65 74 |(src des|t)..(let|
|00003630| 20 28 28 73 20 28 65 6e | 63 6f 64 65 2d 61 64 64 | ((s (en|code-add|
|00003640| 72 65 73 73 20 73 72 63 | 29 29 28 64 20 28 65 6e |ress src|))(d (en|
|00003650| 63 6f 64 65 2d 61 64 64 | 72 65 73 73 20 64 65 73 |code-add|ress des|
|00003660| 74 29 29 29 0d 09 09 28 | 75 6e 6c 65 73 73 20 28 |t)))...(|unless (|
|00003670| 6f 72 20 28 3d 20 28 65 | 6e 63 6f 64 65 64 2d 61 |or (= (e|ncoded-a|
|00003680| 64 64 72 65 73 73 2d 6d | 6f 64 65 20 73 29 20 30 |ddress-m|ode s) 0|
|00003690| 29 20 0d 09 09 09 09 09 | 28 3d 20 28 65 6e 63 6f |) ......|(= (enco|
|000036a0| 64 65 64 2d 61 64 64 72 | 65 73 73 2d 6d 6f 64 65 |ded-addr|ess-mode|
|000036b0| 20 64 29 20 30 29 29 0d | 09 09 09 28 65 72 72 6f | d) 0)).|...(erro|
|000036c0| 72 20 22 54 68 65 20 73 | 6f 75 72 63 65 20 6f 72 |r "The s|ource or|
|000036d0| 20 64 65 73 74 69 6e 61 | 74 69 6f 6e 20 6f 66 20 | destina|tion of |
|000036e0| 27 73 75 62 27 20 6d 75 | 73 74 20 62 65 20 61 20 |'sub' mu|st be a |
|000036f0| 64 2d 72 65 67 69 73 74 | 65 72 22 29 29 0d 09 09 |d-regist|er"))...|
|00003700| 28 69 66 20 28 3d 20 28 | 65 6e 63 6f 64 65 64 2d |(if (= (|encoded-|
|00003710| 61 64 64 72 65 73 73 2d | 6d 6f 64 65 20 73 29 20 |address-|mode s) |
|00003720| 30 29 09 09 3b 20 69 66 | 20 44 2d 72 65 67 69 73 |0)..; if| D-regis|
|00003730| 74 65 72 20 69 73 20 73 | 6f 75 72 63 65 0d 09 09 |ter is s|ource...|
|00003740| 09 60 28 2c 28 2b 20 23 | 78 39 30 30 30 20 0d 09 |.`(,(+ #|x9000 ..|
|00003750| 09 09 09 28 2a 20 28 65 | 6e 63 6f 64 65 64 2d 61 |...(* (e|ncoded-a|
|00003760| 64 64 72 65 73 73 2d 72 | 65 67 20 73 29 20 23 78 |ddress-r|eg s) #x|
|00003770| 32 30 30 29 3b 20 73 6f | 75 72 63 65 20 72 65 67 |200); so|urce reg|
|00003780| 69 73 74 65 72 20 62 69 | 74 73 20 39 2d 31 31 0d |ister bi|ts 9-11.|
|00003790| 09 09 09 09 28 2a 20 36 | 20 23 78 34 30 29 09 09 |....(* 6| #x40)..|
|000037a0| 09 09 09 09 3b 20 6f 70 | 2d 6d 6f 64 65 20 62 69 |....; op|-mode bi|
|000037b0| 74 73 20 36 2d 38 0d 09 | 09 09 09 28 2a 20 28 65 |ts 6-8..|...(* (e|
|000037c0| 6e 63 6f 64 65 64 2d 61 | 64 64 72 65 73 73 2d 6d |ncoded-a|ddress-m|
|000037d0| 6f 64 65 20 64 29 20 23 | 78 38 29 3b 20 64 65 73 |ode d) #|x8); des|
|000037e0| 74 20 6d 6f 64 65 20 62 | 69 74 73 20 33 2d 35 0d |t mode b|its 3-5.|
|000037f0| 09 09 09 09 28 65 6e 63 | 6f 64 65 64 2d 61 64 64 |....(enc|oded-add|
|00003800| 72 65 73 73 2d 72 65 67 | 20 64 29 29 09 09 3b 20 |ress-reg| d))..; |
|00003810| 64 65 73 74 20 72 65 67 | 69 73 74 65 72 0d 09 09 |dest reg|ister...|
|00003820| 09 09 2c 40 28 65 6e 63 | 6f 64 65 64 2d 61 64 64 |..,@(enc|oded-add|
|00003830| 72 65 73 73 2d 64 61 74 | 61 20 64 29 29 0d 09 09 |ress-dat|a d))...|
|00003840| 09 09 09 09 09 09 09 09 | 3b 20 65 6c 73 65 20 44 |........|; else D|
|00003850| 2d 72 65 67 69 73 74 65 | 72 20 69 73 20 64 65 73 |-registe|r is des|
|00003860| 74 69 6e 61 74 69 6f 6e | 0d 09 09 09 60 28 2c 28 |tination|....`(,(|
|00003870| 2b 20 23 78 39 30 30 30 | 20 0d 09 09 09 09 28 2a |+ #x9000| .....(*|
|00003880| 20 28 65 6e 63 6f 64 65 | 64 2d 61 64 64 72 65 73 | (encode|d-addres|
|00003890| 73 2d 72 65 67 20 64 29 | 20 23 78 32 30 30 29 3b |s-reg d)| #x200);|
|000038a0| 20 64 65 73 74 20 72 65 | 67 69 73 74 65 72 20 62 | dest re|gister b|
|000038b0| 69 74 73 20 39 2d 31 31 | 0d 09 09 09 09 28 2a 20 |its 9-11|.....(* |
|000038c0| 32 20 23 78 34 30 29 09 | 09 09 09 09 09 3b 20 6f |2 #x40).|.....; o|
|000038d0| 70 2d 6d 6f 64 65 20 62 | 69 74 73 20 36 2d 38 0d |p-mode b|its 6-8.|
|000038e0| 09 09 09 09 28 2a 20 28 | 65 6e 63 6f 64 65 64 2d |....(* (|encoded-|
|000038f0| 61 64 64 72 65 73 73 2d | 6d 6f 64 65 20 73 29 20 |address-|mode s) |
|00003900| 23 78 38 29 3b 20 73 72 | 63 20 6d 6f 64 65 20 62 |#x8); sr|c mode b|
|00003910| 69 74 73 20 33 2d 35 0d | 09 09 09 09 28 65 6e 63 |its 3-5.|....(enc|
|00003920| 6f 64 65 64 2d 61 64 64 | 72 65 73 73 2d 72 65 67 |oded-add|ress-reg|
|00003930| 20 73 29 29 09 09 3b 20 | 73 72 63 20 72 65 67 69 | s))..; |src regi|
|00003940| 73 74 65 72 0d 09 09 09 | 09 2c 40 28 65 6e 63 6f |ster....|.,@(enco|
|00003950| 64 65 64 2d 61 64 64 72 | 65 73 73 2d 64 61 74 61 |ded-addr|ess-data|
|00003960| 20 73 29 29 29 29 29 0d | 0d 28 64 65 66 6d 61 63 | s))))).|.(defmac|
|00003970| 72 6f 20 63 6d 70 2e 6c | 20 28 73 72 63 20 64 65 |ro cmp.l| (src de|
|00003980| 73 74 29 0d 09 28 6c 65 | 74 20 28 28 73 20 28 65 |st)..(le|t ((s (e|
|00003990| 6e 63 6f 64 65 2d 61 64 | 64 72 65 73 73 20 73 72 |ncode-ad|dress sr|
|000039a0| 63 29 29 28 64 20 28 65 | 6e 63 6f 64 65 2d 61 64 |c))(d (e|ncode-ad|
|000039b0| 64 72 65 73 73 20 64 65 | 73 74 29 29 29 0d 09 09 |dress de|st)))...|
|000039c0| 28 75 6e 6c 65 73 73 20 | 28 3d 20 28 65 6e 63 6f |(unless |(= (enco|
|000039d0| 64 65 64 2d 61 64 64 72 | 65 73 73 2d 6d 6f 64 65 |ded-addr|ess-mode|
|000039e0| 20 64 29 20 30 29 0d 09 | 09 09 28 65 72 72 6f 72 | d) 0)..|..(error|
|000039f0| 20 22 54 68 65 20 64 65 | 73 74 69 6e 61 74 69 6f | "The de|stinatio|
|00003a00| 6e 20 6f 66 20 27 63 6d | 70 27 20 6d 75 73 74 20 |n of 'cm|p' must |
|00003a10| 62 65 20 61 20 64 2d 72 | 65 67 69 73 74 65 72 22 |be a d-r|egister"|
|00003a20| 29 29 0d 09 09 60 28 2c | 28 2b 20 23 78 62 30 30 |))...`(,|(+ #xb00|
|00003a30| 30 20 0d 09 09 09 28 2a | 20 28 65 6e 63 6f 64 65 |0 ....(*| (encode|
|00003a40| 64 2d 61 64 64 72 65 73 | 73 2d 72 65 67 20 64 29 |d-addres|s-reg d)|
|00003a50| 20 23 78 32 30 30 29 3b | 20 64 65 73 74 20 72 65 | #x200);| dest re|
|00003a60| 67 69 73 74 65 72 20 62 | 69 74 73 20 39 2d 31 31 |gister b|its 9-11|
|00003a70| 0d 09 09 09 28 2a 20 32 | 20 23 78 34 30 29 09 09 |....(* 2| #x40)..|
|00003a80| 09 09 09 09 3b 20 6f 70 | 2d 6d 6f 64 65 20 62 69 |....; op|-mode bi|
|00003a90| 74 73 20 36 2d 38 0d 09 | 09 09 28 2a 20 28 65 6e |ts 6-8..|..(* (en|
|00003aa0| 63 6f 64 65 64 2d 61 64 | 64 72 65 73 73 2d 6d 6f |coded-ad|dress-mo|
|00003ab0| 64 65 20 73 29 20 23 78 | 38 29 3b 20 73 72 63 20 |de s) #x|8); src |
|00003ac0| 6d 6f 64 65 20 62 69 74 | 73 20 33 2d 35 0d 09 09 |mode bit|s 3-5...|
|00003ad0| 09 28 65 6e 63 6f 64 65 | 64 2d 61 64 64 72 65 73 |.(encode|d-addres|
|00003ae0| 73 2d 72 65 67 20 73 29 | 29 09 09 3b 20 73 72 63 |s-reg s)|)..; src|
|00003af0| 20 72 65 67 69 73 74 65 | 72 0d 09 09 09 2c 40 28 | registe|r....,@(|
|00003b00| 65 6e 63 6f 64 65 64 2d | 61 64 64 72 65 73 73 2d |encoded-|address-|
|00003b10| 64 61 74 61 20 73 29 29 | 29 29 0d 0d 28 64 65 66 |data s))|))..(def|
|00003b20| 6d 61 63 72 6f 20 74 73 | 74 2e 6c 20 28 64 65 73 |macro ts|t.l (des|
|00003b30| 74 29 0d 09 28 6c 65 74 | 20 28 28 64 20 28 65 6e |t)..(let| ((d (en|
|00003b40| 63 6f 64 65 2d 61 64 64 | 72 65 73 73 20 64 65 73 |code-add|ress des|
|00003b50| 74 29 29 29 0d 09 09 60 | 28 2c 28 2b 20 23 78 34 |t)))...`|(,(+ #x4|
|00003b60| 41 30 30 0d 09 09 09 09 | 28 2a 20 23 78 34 30 20 |A00.....|(* #x40 |
|00003b70| 32 29 09 09 09 09 09 09 | 3b 20 73 69 7a 65 20 3d |2)......|; size =|
|00003b80| 20 6c 6f 6e 67 0d 09 09 | 09 09 28 2a 20 28 65 6e | long...|..(* (en|
|00003b90| 63 6f 64 65 64 2d 61 64 | 64 72 65 73 73 2d 6d 6f |coded-ad|dress-mo|
|00003ba0| 64 65 20 64 29 20 23 78 | 38 29 3b 20 64 65 73 74 |de d) #x|8); dest|
|00003bb0| 20 6d 6f 64 65 20 62 69 | 74 73 20 33 2d 35 0d 09 | mode bi|ts 3-5..|
|00003bc0| 09 09 09 28 65 6e 63 6f | 64 65 64 2d 61 64 64 72 |...(enco|ded-addr|
|00003bd0| 65 73 73 2d 72 65 67 20 | 64 29 29 09 09 3b 20 64 |ess-reg |d))..; d|
|00003be0| 65 73 74 20 72 65 67 69 | 73 74 65 72 0d 09 09 09 |est regi|ster....|
|00003bf0| 09 2c 40 28 65 6e 63 6f | 64 65 64 2d 61 64 64 72 |.,@(enco|ded-addr|
|00003c00| 65 73 73 2d 64 61 74 61 | 20 64 29 29 29 29 0d 0d |ess-data| d))))..|
|00003c10| 28 64 65 66 6d 61 63 72 | 6f 20 73 75 62 69 2e 6c |(defmacr|o subi.l|
|00003c20| 20 28 73 72 63 20 64 65 | 73 74 29 0d 09 28 69 6e | (src de|st)..(in|
|00003c30| 63 66 20 2a 61 73 73 65 | 6d 62 6c 65 72 2d 6c 6f |cf *asse|mbler-lo|
|00003c40| 63 61 6c 2d 61 64 64 72 | 65 73 73 2a 20 34 29 0d |cal-addr|ess* 4).|
|00003c50| 09 28 6c 65 74 20 28 28 | 73 20 73 72 63 29 28 64 |.(let ((|s src)(d|
|00003c60| 20 28 65 6e 63 6f 64 65 | 2d 61 64 64 72 65 73 73 | (encode|-address|
|00003c70| 20 64 65 73 74 29 29 29 | 0d 09 09 28 75 6e 6c 65 | dest)))|...(unle|
|00003c80| 73 73 20 28 69 6e 74 65 | 67 65 72 70 20 73 29 0d |ss (inte|gerp s).|
|00003c90| 09 09 09 28 65 72 72 6f | 72 20 22 54 68 65 20 73 |...(erro|r "The s|
|00003ca0| 6f 75 72 63 65 20 6f 66 | 20 27 73 75 62 69 27 20 |ource of| 'subi' |
|00003cb0| 6d 75 73 74 20 62 65 20 | 61 6e 20 69 6e 74 65 67 |must be |an integ|
|00003cc0| 65 72 22 29 29 0d 09 09 | 60 28 2c 28 2b 20 23 78 |er"))...|`(,(+ #x|
|00003cd0| 30 34 38 30 20 0d 09 09 | 09 09 28 2a 20 28 65 6e |0480 ...|..(* (en|
|00003ce0| 63 6f 64 65 64 2d 61 64 | 64 72 65 73 73 2d 6d 6f |coded-ad|dress-mo|
|00003cf0| 64 65 20 64 29 20 23 78 | 38 29 3b 20 64 65 73 74 |de d) #x|8); dest|
|00003d00| 20 6d 6f 64 65 20 62 69 | 74 73 20 33 2d 35 0d 09 | mode bi|ts 3-5..|
|00003d10| 09 09 09 28 65 6e 63 6f | 64 65 64 2d 61 64 64 72 |...(enco|ded-addr|
|00003d20| 65 73 73 2d 72 65 67 20 | 64 29 29 09 09 3b 20 64 |ess-reg |d))..; d|
|00003d30| 65 73 74 20 72 65 67 69 | 73 74 65 72 0d 09 09 09 |est regi|ster....|
|00003d40| 09 2c 40 28 6d 75 6c 74 | 69 70 6c 65 2d 76 61 6c |.,@(mult|iple-val|
|00003d50| 75 65 2d 6c 69 73 74 20 | 28 74 72 75 6e 63 61 74 |ue-list |(truncat|
|00003d60| 65 20 73 20 23 78 31 30 | 30 30 30 29 29 0d 09 09 |e s #x10|000))...|
|00003d70| 09 09 2c 40 28 65 6e 63 | 6f 64 65 64 2d 61 64 64 |..,@(enc|oded-add|
|00003d80| 72 65 73 73 2d 64 61 74 | 61 20 64 29 29 29 29 0d |ress-dat|a d)))).|
|00003d90| 0d 28 64 65 66 6d 61 63 | 72 6f 20 63 6c 72 2e 6c |.(defmac|ro clr.l|
|00003da0| 20 28 64 65 73 74 29 0d | 09 28 6c 65 74 20 28 28 | (dest).|.(let ((|
|00003db0| 64 20 28 65 6e 63 6f 64 | 65 2d 61 64 64 72 65 73 |d (encod|e-addres|
|00003dc0| 73 20 64 65 73 74 29 29 | 29 0d 09 09 60 28 2c 28 |s dest))|)...`(,(|
|00003dd0| 2b 20 23 78 34 32 30 30 | 0d 09 09 09 09 28 2a 20 |+ #x4200|.....(* |
|00003de0| 23 78 34 30 20 32 29 09 | 09 09 09 09 09 3b 20 73 |#x40 2).|.....; s|
|00003df0| 69 7a 65 20 3d 20 6c 6f | 6e 67 0d 09 09 09 09 28 |ize = lo|ng.....(|
|00003e00| 2a 20 28 65 6e 63 6f 64 | 65 64 2d 61 64 64 72 65 |* (encod|ed-addre|
|00003e10| 73 73 2d 6d 6f 64 65 20 | 64 29 20 23 78 38 29 3b |ss-mode |d) #x8);|
|00003e20| 20 64 65 73 74 20 6d 6f | 64 65 20 62 69 74 73 20 | dest mo|de bits |
|00003e30| 33 2d 35 0d 09 09 09 09 | 28 65 6e 63 6f 64 65 64 |3-5.....|(encoded|
|00003e40| 2d 61 64 64 72 65 73 73 | 2d 72 65 67 20 64 29 29 |-address|-reg d))|
|00003e50| 09 09 3b 20 64 65 73 74 | 20 72 65 67 69 73 74 65 |..; dest| registe|
|00003e60| 72 0d 09 09 09 09 2c 40 | 28 65 6e 63 6f 64 65 64 |r.....,@|(encoded|
|00003e70| 2d 61 64 64 72 65 73 73 | 2d 64 61 74 61 20 64 29 |-address|-data d)|
|00003e80| 29 29 29 0d 0d 28 64 65 | 66 6d 61 63 72 6f 20 6c |)))..(de|fmacro l|
|00003e90| 65 61 20 28 73 72 63 20 | 64 65 73 74 29 0d 09 28 |ea (src |dest)..(|
|00003ea0| 6c 65 74 20 28 28 73 20 | 28 65 6e 63 6f 64 65 2d |let ((s |(encode-|
|00003eb0| 61 64 64 72 65 73 73 20 | 73 72 63 29 29 28 64 20 |address |src))(d |
|00003ec0| 28 65 6e 63 6f 64 65 2d | 61 64 64 72 65 73 73 20 |(encode-|address |
|00003ed0| 64 65 73 74 29 29 29 0d | 09 09 28 75 6e 6c 65 73 |dest))).|..(unles|
|00003ee0| 73 20 28 3d 20 28 65 6e | 63 6f 64 65 64 2d 61 64 |s (= (en|coded-ad|
|00003ef0| 64 72 65 73 73 2d 6d 6f | 64 65 20 64 29 20 31 29 |dress-mo|de d) 1)|
|00003f00| 0d 09 09 09 28 65 72 72 | 6f 72 20 22 54 68 65 20 |....(err|or "The |
|00003f10| 64 65 73 74 69 6e 61 74 | 69 6f 6e 20 6f 66 20 27 |destinat|ion of '|
|00003f20| 6c 65 61 27 20 6d 75 73 | 74 20 62 65 20 61 6e 20 |lea' mus|t be an |
|00003f30| 61 2d 72 65 67 69 73 74 | 65 72 22 29 29 0d 09 09 |a-regist|er"))...|
|00003f40| 60 28 2c 28 2b 20 23 78 | 34 31 43 30 0d 09 09 09 |`(,(+ #x|41C0....|
|00003f50| 09 28 2a 20 23 78 32 30 | 30 20 28 65 6e 63 6f 64 |.(* #x20|0 (encod|
|00003f60| 65 64 2d 61 64 64 72 65 | 73 73 2d 72 65 67 20 64 |ed-addre|ss-reg d|
|00003f70| 29 29 3b 20 64 65 73 74 | 20 72 65 67 69 73 74 65 |)); dest| registe|
|00003f80| 72 20 62 69 74 73 20 39 | 2d 31 31 0d 09 09 09 09 |r bits 9|-11.....|
|00003f90| 28 2a 20 28 65 6e 63 6f | 64 65 64 2d 61 64 64 72 |(* (enco|ded-addr|
|00003fa0| 65 73 73 2d 6d 6f 64 65 | 20 73 29 20 23 78 38 29 |ess-mode| s) #x8)|
|00003fb0| 3b 20 73 72 63 20 6d 6f | 64 65 20 62 69 74 73 20 |; src mo|de bits |
|00003fc0| 33 2d 35 0d 09 09 09 09 | 28 65 6e 63 6f 64 65 64 |3-5.....|(encoded|
|00003fd0| 2d 61 64 64 72 65 73 73 | 2d 72 65 67 20 73 29 29 |-address|-reg s))|
|00003fe0| 09 09 3b 20 73 72 63 20 | 72 65 67 69 73 74 65 72 |..; src |register|
|00003ff0| 0d 09 09 09 09 2c 40 28 | 65 6e 63 6f 64 65 64 2d |.....,@(|encoded-|
|00004000| 61 64 64 72 65 73 73 2d | 64 61 74 61 20 73 29 29 |address-|data s))|
|00004010| 29 29 0d 0d 28 64 65 66 | 6d 61 63 72 6f 20 6a 73 |))..(def|macro js|
|00004020| 72 20 28 64 73 74 29 0d | 0d 09 28 69 66 20 28 73 |r (dst).|..(if (s|
|00004030| 79 6d 62 6f 6c 70 20 64 | 73 74 29 20 0d 09 09 28 |ymbolp d|st) ...(|
|00004040| 70 72 6f 67 6e 0d 09 09 | 09 28 61 64 64 2d 72 65 |progn...|.(add-re|
|00004050| 66 65 72 65 6e 63 65 20 | 60 28 73 79 6d 62 6f 6c |ference |`(symbol|
|00004060| 2d 76 61 6c 75 65 20 2c | 64 73 74 29 29 0d 09 09 |-value ,|dst))...|
|00004070| 09 28 73 65 74 71 20 64 | 73 74 20 28 73 79 6d 62 |.(setq d|st (symb|
|00004080| 6f 6c 2d 76 61 6c 75 65 | 20 64 73 74 29 29 29 29 |ol-value| dst))))|
|00004090| 0d 09 09 09 0d 09 28 69 | 66 20 28 63 6f 6e 73 70 |......(i|f (consp|
|000040a0| 20 64 73 74 29 0d 09 09 | 28 69 66 20 28 65 71 20 | dst)...|(if (eq |
|000040b0| 28 63 61 72 20 64 73 74 | 29 20 27 66 75 6e 63 74 |(car dst|) 'funct|
|000040c0| 69 6f 6e 29 0d 09 09 09 | 28 70 72 6f 67 6e 0d 09 |ion)....|(progn..|
|000040d0| 09 09 09 28 61 64 64 2d | 72 65 66 65 72 65 6e 63 |...(add-|referenc|
|000040e0| 65 20 64 73 74 29 0d 09 | 09 09 09 28 72 65 74 75 |e dst)..|...(retu|
|000040f0| 72 6e 20 28 63 6f 6e 73 | 20 23 78 34 65 62 39 20 |rn (cons| #x4eb9 |
|00004100| 0d 09 09 09 09 09 28 6d | 75 6c 74 69 70 6c 65 2d |......(m|ultiple-|
|00004110| 76 61 6c 75 65 2d 6c 69 | 73 74 20 0d 09 09 09 09 |value-li|st .....|
|00004120| 09 09 28 74 72 75 6e 63 | 61 74 65 20 28 65 78 65 |..(trunc|ate (exe|
|00004130| 63 2d 61 64 64 72 65 73 | 73 20 28 63 61 64 72 20 |c-addres|s (cadr |
|00004140| 64 73 74 29 29 20 23 78 | 31 30 30 30 30 29 29 29 |dst)) #x|10000)))|
|00004150| 29 29 29 0d 09 09 3b 3b | 20 65 6c 73 65 0d 09 09 |)))...;;| else...|
|00004160| 28 65 72 72 6f 72 20 22 | 49 6e 76 61 6c 69 64 20 |(error "|Invalid |
|00004170| 64 65 73 74 69 6e 61 74 | 69 6f 6e 2e 7e 25 49 6e |destinat|ion.~%In|
|00004180| 73 74 72 75 63 74 69 6f | 6e 3a 20 6a 73 72 20 20 |structio|n: jsr |
|00004190| 44 65 73 74 69 6e 61 74 | 69 6f 6e 3a 20 7e 41 22 |Destinat|ion: ~A"|
|000041a0| 20 64 73 74 29 29 0d 09 | 09 0d 09 28 6c 65 74 20 | dst))..|...(let |
|000041b0| 28 28 64 20 28 65 6e 63 | 6f 64 65 2d 61 64 64 72 |((d (enc|ode-addr|
|000041c0| 65 73 73 20 64 73 74 29 | 29 29 0d 09 09 28 61 70 |ess dst)|))...(ap|
|000041d0| 70 65 6e 64 0d 09 09 09 | 28 6c 69 73 74 20 28 2b |pend....|(list (+|
|000041e0| 20 23 78 34 65 38 30 0d | 09 09 09 09 09 28 2a 20 | #x4e80.|.....(* |
|000041f0| 28 65 6e 63 6f 64 65 64 | 2d 61 64 64 72 65 73 73 |(encoded|-address|
|00004200| 2d 6d 6f 64 65 20 64 29 | 20 23 78 38 29 3b 20 64 |-mode d)| #x8); d|
|00004210| 65 73 74 20 6d 6f 64 65 | 20 62 69 74 73 20 33 2d |est mode| bits 3-|
|00004220| 35 0d 09 09 09 09 09 28 | 65 6e 63 6f 64 65 64 2d |5......(|encoded-|
|00004230| 61 64 64 72 65 73 73 2d | 72 65 67 20 64 29 29 29 |address-|reg d)))|
|00004240| 09 09 3b 20 64 65 73 74 | 20 72 65 67 69 73 74 65 |..; dest| registe|
|00004250| 72 0d 09 09 09 28 65 6e | 63 6f 64 65 64 2d 61 64 |r....(en|coded-ad|
|00004260| 64 72 65 73 73 2d 64 61 | 74 61 20 64 29 29 29 29 |dress-da|ta d))))|
|00004270| 0d 0d 28 64 65 66 6d 61 | 63 72 6f 20 62 72 61 20 |..(defma|cro bra |
|00004280| 28 64 65 73 74 29 20 60 | 28 23 78 36 30 30 30 20 |(dest) `|(#x6000 |
|00004290| 2c 64 65 73 74 29 29 0d | 28 64 65 66 6d 61 63 72 |,dest)).|(defmacr|
|000042a0| 6f 20 62 73 72 20 28 64 | 65 73 74 29 20 60 28 23 |o bsr (d|est) `(#|
|000042b0| 78 36 31 30 30 20 2c 64 | 65 73 74 29 29 0d 28 64 |x6100 ,d|est)).(d|
|000042c0| 65 66 6d 61 63 72 6f 20 | 62 68 69 20 28 64 65 73 |efmacro |bhi (des|
|000042d0| 74 29 20 60 28 23 78 36 | 32 30 30 20 2c 64 65 73 |t) `(#x6|200 ,des|
|000042e0| 74 29 29 0d 28 64 65 66 | 6d 61 63 72 6f 20 62 6c |t)).(def|macro bl|
|000042f0| 73 20 28 64 65 73 74 29 | 20 60 28 23 78 36 33 30 |s (dest)| `(#x630|
|00004300| 30 20 2c 64 65 73 74 29 | 29 0d 28 64 65 66 6d 61 |0 ,dest)|).(defma|
|00004310| 63 72 6f 20 62 63 63 20 | 28 64 65 73 74 29 20 60 |cro bcc |(dest) `|
|00004320| 28 23 78 36 34 30 30 20 | 2c 64 65 73 74 29 29 0d |(#x6400 |,dest)).|
|00004330| 28 64 65 66 6d 61 63 72 | 6f 20 62 63 73 20 28 64 |(defmacr|o bcs (d|
|00004340| 65 73 74 29 20 60 28 23 | 78 36 35 30 30 20 2c 64 |est) `(#|x6500 ,d|
|00004350| 65 73 74 29 29 0d 28 64 | 65 66 6d 61 63 72 6f 20 |est)).(d|efmacro |
|00004360| 62 6e 65 20 28 64 65 73 | 74 29 20 60 28 23 78 36 |bne (des|t) `(#x6|
|00004370| 36 30 30 20 2c 64 65 73 | 74 29 29 0d 28 64 65 66 |600 ,des|t)).(def|
|00004380| 6d 61 63 72 6f 20 62 65 | 71 20 28 64 65 73 74 29 |macro be|q (dest)|
|00004390| 20 60 28 23 78 36 37 30 | 30 20 2c 64 65 73 74 29 | `(#x670|0 ,dest)|
|000043a0| 29 0d 28 64 65 66 6d 61 | 63 72 6f 20 62 76 63 20 |).(defma|cro bvc |
|000043b0| 28 64 65 73 74 29 20 60 | 28 23 78 36 38 30 30 20 |(dest) `|(#x6800 |
|000043c0| 2c 64 65 73 74 29 29 0d | 28 64 65 66 6d 61 63 72 |,dest)).|(defmacr|
|000043d0| 6f 20 62 76 73 20 28 64 | 65 73 74 29 20 60 28 23 |o bvs (d|est) `(#|
|000043e0| 78 36 39 30 30 20 2c 64 | 65 73 74 29 29 0d 28 64 |x6900 ,d|est)).(d|
|000043f0| 65 66 6d 61 63 72 6f 20 | 62 70 6c 20 28 64 65 73 |efmacro |bpl (des|
|00004400| 74 29 20 60 28 23 78 36 | 61 30 30 20 2c 64 65 73 |t) `(#x6|a00 ,des|
|00004410| 74 29 29 0d 28 64 65 66 | 6d 61 63 72 6f 20 62 6d |t)).(def|macro bm|
|00004420| 69 20 28 64 65 73 74 29 | 20 60 28 23 78 36 62 30 |i (dest)| `(#x6b0|
|00004430| 30 20 2c 64 65 73 74 29 | 29 0d 28 64 65 66 6d 61 |0 ,dest)|).(defma|
|00004440| 63 72 6f 20 62 67 65 20 | 28 64 65 73 74 29 20 60 |cro bge |(dest) `|
|00004450| 28 23 78 36 63 30 30 20 | 2c 64 65 73 74 29 29 0d |(#x6c00 |,dest)).|
|00004460| 28 64 65 66 6d 61 63 72 | 6f 20 62 6c 74 20 28 64 |(defmacr|o blt (d|
|00004470| 65 73 74 29 20 60 28 23 | 78 36 64 30 30 20 2c 64 |est) `(#|x6d00 ,d|
|00004480| 65 73 74 29 29 0d 28 64 | 65 66 6d 61 63 72 6f 20 |est)).(d|efmacro |
|00004490| 62 67 74 20 28 64 65 73 | 74 29 20 60 28 23 78 36 |bgt (des|t) `(#x6|
|000044a0| 65 30 30 20 2c 64 65 73 | 74 29 29 0d 28 64 65 66 |e00 ,des|t)).(def|
|000044b0| 6d 61 63 72 6f 20 62 6c | 65 20 28 64 65 73 74 29 |macro bl|e (dest)|
|000044c0| 20 60 28 23 78 36 66 30 | 30 20 2c 64 65 73 74 29 | `(#x6f0|0 ,dest)|
|000044d0| 29 0d 09 0d 28 73 65 74 | 66 20 28 67 65 74 20 27 |)...(set|f (get '|
|000044e0| 64 30 20 27 70 6f 73 74 | 2d 69 6e 63 72 65 6d 65 |d0 'post|-increme|
|000044f0| 6e 74 2d 6d 61 73 6b 29 | 20 23 78 30 30 30 31 29 |nt-mask)| #x0001)|
|00004500| 0d 28 73 65 74 66 20 28 | 67 65 74 20 27 64 31 20 |.(setf (|get 'd1 |
|00004510| 27 70 6f 73 74 2d 69 6e | 63 72 65 6d 65 6e 74 2d |'post-in|crement-|
|00004520| 6d 61 73 6b 29 20 23 78 | 30 30 30 32 29 0d 28 73 |mask) #x|0002).(s|
|00004530| 65 74 66 20 28 67 65 74 | 20 27 64 32 20 27 70 6f |etf (get| 'd2 'po|
|00004540| 73 74 2d 69 6e 63 72 65 | 6d 65 6e 74 2d 6d 61 73 |st-incre|ment-mas|
|00004550| 6b 29 20 23 78 30 30 30 | 34 29 0d 28 73 65 74 66 |k) #x000|4).(setf|
|00004560| 20 28 67 65 74 20 27 64 | 33 20 27 70 6f 73 74 2d | (get 'd|3 'post-|
|00004570| 69 6e 63 72 65 6d 65 6e | 74 2d 6d 61 73 6b 29 20 |incremen|t-mask) |
|00004580| 23 78 30 30 30 38 29 0d | 28 73 65 74 66 20 28 67 |#x0008).|(setf (g|
|00004590| 65 74 20 27 64 34 20 27 | 70 6f 73 74 2d 69 6e 63 |et 'd4 '|post-inc|
|000045a0| 72 65 6d 65 6e 74 2d 6d | 61 73 6b 29 20 23 78 30 |rement-m|ask) #x0|
|000045b0| 30 31 30 29 0d 28 73 65 | 74 66 20 28 67 65 74 20 |010).(se|tf (get |
|000045c0| 27 64 35 20 27 70 6f 73 | 74 2d 69 6e 63 72 65 6d |'d5 'pos|t-increm|
|000045d0| 65 6e 74 2d 6d 61 73 6b | 29 20 23 78 30 30 32 30 |ent-mask|) #x0020|
|000045e0| 29 0d 28 73 65 74 66 20 | 28 67 65 74 20 27 64 36 |).(setf |(get 'd6|
|000045f0| 20 27 70 6f 73 74 2d 69 | 6e 63 72 65 6d 65 6e 74 | 'post-i|ncrement|
|00004600| 2d 6d 61 73 6b 29 20 23 | 78 30 30 34 30 29 0d 28 |-mask) #|x0040).(|
|00004610| 73 65 74 66 20 28 67 65 | 74 20 27 64 37 20 27 70 |setf (ge|t 'd7 'p|
|00004620| 6f 73 74 2d 69 6e 63 72 | 65 6d 65 6e 74 2d 6d 61 |ost-incr|ement-ma|
|00004630| 73 6b 29 20 23 78 30 30 | 38 30 29 0d 28 73 65 74 |sk) #x00|80).(set|
|00004640| 66 20 28 67 65 74 20 27 | 61 30 20 27 70 6f 73 74 |f (get '|a0 'post|
|00004650| 2d 69 6e 63 72 65 6d 65 | 6e 74 2d 6d 61 73 6b 29 |-increme|nt-mask)|
|00004660| 20 23 78 30 31 30 30 29 | 0d 28 73 65 74 66 20 28 | #x0100)|.(setf (|
|00004670| 67 65 74 20 27 61 31 20 | 27 70 6f 73 74 2d 69 6e |get 'a1 |'post-in|
|00004680| 63 72 65 6d 65 6e 74 2d | 6d 61 73 6b 29 20 23 78 |crement-|mask) #x|
|00004690| 30 32 30 30 29 0d 28 73 | 65 74 66 20 28 67 65 74 |0200).(s|etf (get|
|000046a0| 20 27 61 32 20 27 70 6f | 73 74 2d 69 6e 63 72 65 | 'a2 'po|st-incre|
|000046b0| 6d 65 6e 74 2d 6d 61 73 | 6b 29 20 23 78 30 34 30 |ment-mas|k) #x040|
|000046c0| 30 29 0d 28 73 65 74 66 | 20 28 67 65 74 20 27 61 |0).(setf| (get 'a|
|000046d0| 33 20 27 70 6f 73 74 2d | 69 6e 63 72 65 6d 65 6e |3 'post-|incremen|
|000046e0| 74 2d 6d 61 73 6b 29 20 | 23 78 30 38 30 30 29 0d |t-mask) |#x0800).|
|000046f0| 28 73 65 74 66 20 28 67 | 65 74 20 27 61 34 20 27 |(setf (g|et 'a4 '|
|00004700| 70 6f 73 74 2d 69 6e 63 | 72 65 6d 65 6e 74 2d 6d |post-inc|rement-m|
|00004710| 61 73 6b 29 20 23 78 31 | 30 30 30 29 0d 28 73 65 |ask) #x1|000).(se|
|00004720| 74 66 20 28 67 65 74 20 | 27 61 35 20 27 70 6f 73 |tf (get |'a5 'pos|
|00004730| 74 2d 69 6e 63 72 65 6d | 65 6e 74 2d 6d 61 73 6b |t-increm|ent-mask|
|00004740| 29 20 23 78 32 30 30 30 | 29 0d 28 73 65 74 66 20 |) #x2000|).(setf |
|00004750| 28 67 65 74 20 27 61 36 | 20 27 70 6f 73 74 2d 69 |(get 'a6| 'post-i|
|00004760| 6e 63 72 65 6d 65 6e 74 | 2d 6d 61 73 6b 29 20 23 |ncrement|-mask) #|
|00004770| 78 34 30 30 30 29 0d 28 | 73 65 74 66 20 28 67 65 |x4000).(|setf (ge|
|00004780| 74 20 27 61 37 20 27 70 | 6f 73 74 2d 69 6e 63 72 |t 'a7 'p|ost-incr|
|00004790| 65 6d 65 6e 74 2d 6d 61 | 73 6b 29 20 23 78 38 30 |ement-ma|sk) #x80|
|000047a0| 30 30 29 0d 0d 28 73 65 | 74 66 20 28 67 65 74 20 |00)..(se|tf (get |
|000047b0| 27 61 37 20 27 70 72 65 | 2d 64 65 63 72 65 6d 65 |'a7 'pre|-decreme|
|000047c0| 6e 74 2d 6d 61 73 6b 29 | 20 23 78 30 30 30 31 29 |nt-mask)| #x0001)|
|000047d0| 0d 28 73 65 74 66 20 28 | 67 65 74 20 27 61 36 20 |.(setf (|get 'a6 |
|000047e0| 27 70 72 65 2d 64 65 63 | 72 65 6d 65 6e 74 2d 6d |'pre-dec|rement-m|
|000047f0| 61 73 6b 29 20 23 78 30 | 30 30 32 29 0d 28 73 65 |ask) #x0|002).(se|
|00004800| 74 66 20 28 67 65 74 20 | 27 61 35 20 27 70 72 65 |tf (get |'a5 'pre|
|00004810| 2d 64 65 63 72 65 6d 65 | 6e 74 2d 6d 61 73 6b 29 |-decreme|nt-mask)|
|00004820| 20 23 78 30 30 30 34 29 | 0d 28 73 65 74 66 20 28 | #x0004)|.(setf (|
|00004830| 67 65 74 20 27 61 34 20 | 27 70 72 65 2d 64 65 63 |get 'a4 |'pre-dec|
|00004840| 72 65 6d 65 6e 74 2d 6d | 61 73 6b 29 20 23 78 30 |rement-m|ask) #x0|
|00004850| 30 30 38 29 0d 28 73 65 | 74 66 20 28 67 65 74 20 |008).(se|tf (get |
|00004860| 27 61 33 20 27 70 72 65 | 2d 64 65 63 72 65 6d 65 |'a3 'pre|-decreme|
|00004870| 6e 74 2d 6d 61 73 6b 29 | 20 23 78 30 30 31 30 29 |nt-mask)| #x0010)|
|00004880| 0d 28 73 65 74 66 20 28 | 67 65 74 20 27 61 32 20 |.(setf (|get 'a2 |
|00004890| 27 70 72 65 2d 64 65 63 | 72 65 6d 65 6e 74 2d 6d |'pre-dec|rement-m|
|000048a0| 61 73 6b 29 20 23 78 30 | 30 32 30 29 0d 28 73 65 |ask) #x0|020).(se|
|000048b0| 74 66 20 28 67 65 74 20 | 27 61 31 20 27 70 72 65 |tf (get |'a1 'pre|
|000048c0| 2d 64 65 63 72 65 6d 65 | 6e 74 2d 6d 61 73 6b 29 |-decreme|nt-mask)|
|000048d0| 20 23 78 30 30 34 30 29 | 0d 28 73 65 74 66 20 28 | #x0040)|.(setf (|
|000048e0| 67 65 74 20 27 61 30 20 | 27 70 72 65 2d 64 65 63 |get 'a0 |'pre-dec|
|000048f0| 72 65 6d 65 6e 74 2d 6d | 61 73 6b 29 20 23 78 30 |rement-m|ask) #x0|
|00004900| 30 38 30 29 0d 28 73 65 | 74 66 20 28 67 65 74 20 |080).(se|tf (get |
|00004910| 27 64 37 20 27 70 72 65 | 2d 64 65 63 72 65 6d 65 |'d7 'pre|-decreme|
|00004920| 6e 74 2d 6d 61 73 6b 29 | 20 23 78 30 31 30 30 29 |nt-mask)| #x0100)|
|00004930| 0d 28 73 65 74 66 20 28 | 67 65 74 20 27 64 36 20 |.(setf (|get 'd6 |
|00004940| 27 70 72 65 2d 64 65 63 | 72 65 6d 65 6e 74 2d 6d |'pre-dec|rement-m|
|00004950| 61 73 6b 29 20 23 78 30 | 32 30 30 29 0d 28 73 65 |ask) #x0|200).(se|
|00004960| 74 66 20 28 67 65 74 20 | 27 64 35 20 27 70 72 65 |tf (get |'d5 'pre|
|00004970| 2d 64 65 63 72 65 6d 65 | 6e 74 2d 6d 61 73 6b 29 |-decreme|nt-mask)|
|00004980| 20 23 78 30 34 30 30 29 | 0d 28 73 65 74 66 20 28 | #x0400)|.(setf (|
|00004990| 67 65 74 20 27 64 34 20 | 27 70 72 65 2d 64 65 63 |get 'd4 |'pre-dec|
|000049a0| 72 65 6d 65 6e 74 2d 6d | 61 73 6b 29 20 23 78 30 |rement-m|ask) #x0|
|000049b0| 38 30 30 29 0d 28 73 65 | 74 66 20 28 67 65 74 20 |800).(se|tf (get |
|000049c0| 27 64 33 20 27 70 72 65 | 2d 64 65 63 72 65 6d 65 |'d3 'pre|-decreme|
|000049d0| 6e 74 2d 6d 61 73 6b 29 | 20 23 78 31 30 30 30 29 |nt-mask)| #x1000)|
|000049e0| 0d 28 73 65 74 66 20 28 | 67 65 74 20 27 64 32 20 |.(setf (|get 'd2 |
|000049f0| 27 70 72 65 2d 64 65 63 | 72 65 6d 65 6e 74 2d 6d |'pre-dec|rement-m|
|00004a00| 61 73 6b 29 20 23 78 32 | 30 30 30 29 0d 28 73 65 |ask) #x2|000).(se|
|00004a10| 74 66 20 28 67 65 74 20 | 27 64 31 20 27 70 72 65 |tf (get |'d1 'pre|
|00004a20| 2d 64 65 63 72 65 6d 65 | 6e 74 2d 6d 61 73 6b 29 |-decreme|nt-mask)|
|00004a30| 20 23 78 34 30 30 30 29 | 0d 28 73 65 74 66 20 28 | #x4000)|.(setf (|
|00004a40| 67 65 74 20 27 64 30 20 | 27 70 72 65 2d 64 65 63 |get 'd0 |'pre-dec|
|00004a50| 72 65 6d 65 6e 74 2d 6d | 61 73 6b 29 20 23 78 38 |rement-m|ask) #x8|
|00004a60| 30 30 30 29 0d 0d 28 64 | 65 66 6d 61 63 72 6f 20 |000)..(d|efmacro |
|00004a70| 6d 6f 76 65 6d 2e 6c 20 | 28 26 72 65 73 74 20 72 |movem.l |(&rest r|
|00004a80| 29 0d 09 28 69 6e 63 66 | 20 2a 61 73 73 65 6d 62 |)..(incf| *assemb|
|00004a90| 6c 65 72 2d 6c 6f 63 61 | 6c 2d 61 64 64 72 65 73 |ler-loca|l-addres|
|00004aa0| 73 2a 20 32 29 0d 09 28 | 6c 65 74 20 28 28 69 6e |s* 2)..(|let ((in|
|00004ab0| 73 74 72 75 63 74 69 6f | 6e 20 30 29 20 28 6d 61 |structio|n 0) (ma|
|00004ac0| 73 6b 20 30 29 20 28 65 | 61 29 29 0d 09 28 69 66 |sk 0) (e|a))..(if|
|00004ad0| 20 28 63 6f 6e 73 70 20 | 28 63 61 72 20 72 29 29 | (consp |(car r))|
|00004ae0| 09 09 3b 3b 20 70 6f 73 | 74 2d 69 6e 63 72 65 6d |..;; pos|t-increm|
|00004af0| 65 6e 74 2d 6d 6f 64 65 | 0d 09 09 28 70 72 6f 67 |ent-mode|...(prog|
|00004b00| 6e 0d 09 09 09 28 73 65 | 74 71 20 65 61 20 28 65 |n....(se|tq ea (e|
|00004b10| 6e 63 6f 64 65 2d 61 64 | 64 72 65 73 73 20 28 63 |ncode-ad|dress (c|
|00004b20| 61 72 20 72 29 29 29 0d | 09 09 09 28 73 65 74 71 |ar r))).|...(setq|
|00004b30| 20 72 20 28 63 64 72 20 | 72 29 29 0d 09 09 09 28 | r (cdr |r))....(|
|00004b40| 73 65 74 71 20 69 6e 73 | 74 72 75 63 74 69 6f 6e |setq ins|truction|
|00004b50| 20 0d 09 09 09 09 28 2b | 20 23 78 34 63 63 30 20 | .....(+| #x4cc0 |
|00004b60| 0d 09 09 09 09 09 28 2a | 20 28 65 6e 63 6f 64 65 |......(*| (encode|
|00004b70| 64 2d 61 64 64 72 65 73 | 73 2d 6d 6f 64 65 20 65 |d-addres|s-mode e|
|00004b80| 61 29 20 38 29 20 0d 09 | 09 09 09 09 28 65 6e 63 |a) 8) ..|....(enc|
|00004b90| 6f 64 65 64 2d 61 64 64 | 72 65 73 73 2d 72 65 67 |oded-add|ress-reg|
|00004ba0| 20 65 61 29 29 29 0d 09 | 09 09 28 64 6f 6c 69 73 | ea)))..|..(dolis|
|00004bb0| 74 20 28 69 20 72 29 20 | 28 73 65 74 71 20 6d 61 |t (i r) |(setq ma|
|00004bc0| 73 6b 20 28 2b 20 6d 61 | 73 6b 20 28 67 65 74 20 |sk (+ ma|sk (get |
|00004bd0| 69 20 27 70 6f 73 74 2d | 69 6e 63 72 65 6d 65 6e |i 'post-|incremen|
|00004be0| 74 2d 6d 61 73 6b 29 29 | 29 29 0d 09 09 09 28 72 |t-mask))|))....(r|
|00004bf0| 65 74 75 72 6e 20 28 6c | 69 73 74 2a 20 69 6e 73 |eturn (l|ist* ins|
|00004c00| 74 72 75 63 74 69 6f 6e | 20 6d 61 73 6b 20 28 65 |truction| mask (e|
|00004c10| 6e 63 6f 64 65 64 2d 61 | 64 64 72 65 73 73 2d 64 |ncoded-a|ddress-d|
|00004c20| 61 74 61 20 65 61 29 29 | 29 29 20 0d 09 09 28 70 |ata ea))|)) ...(p|
|00004c30| 72 6f 67 6e 09 09 09 09 | 3b 3b 20 65 6c 73 65 20 |rogn....|;; else |
|00004c40| 70 72 65 2d 64 65 63 72 | 65 6d 65 6e 74 2d 6d 6f |pre-decr|ement-mo|
|00004c50| 64 65 0d 09 09 09 28 73 | 65 74 71 20 65 61 20 28 |de....(s|etq ea (|
|00004c60| 65 6e 63 6f 64 65 2d 61 | 64 64 72 65 73 73 20 28 |encode-a|ddress (|
|00004c70| 63 61 72 20 28 6c 61 73 | 74 20 72 29 29 29 29 0d |car (las|t r)))).|
|00004c80| 09 09 09 28 73 65 74 71 | 20 69 6e 73 74 72 75 63 |...(setq| instruc|
|00004c90| 74 69 6f 6e 20 0d 09 09 | 09 09 28 2b 20 23 78 34 |tion ...|..(+ #x4|
|00004ca0| 38 63 30 20 0d 09 09 09 | 09 09 28 2a 20 28 65 6e |8c0 ....|..(* (en|
|00004cb0| 63 6f 64 65 64 2d 61 64 | 64 72 65 73 73 2d 6d 6f |coded-ad|dress-mo|
|00004cc0| 64 65 20 65 61 29 20 38 | 29 20 0d 09 09 09 09 09 |de ea) 8|) ......|
|00004cd0| 28 65 6e 63 6f 64 65 64 | 2d 61 64 64 72 65 73 73 |(encoded|-address|
|00004ce0| 2d 72 65 67 20 65 61 29 | 29 29 0d 09 09 09 28 64 |-reg ea)|))....(d|
|00004cf0| 6f 6c 69 73 74 20 28 69 | 20 72 29 20 0d 09 09 09 |olist (i| r) ....|
|00004d00| 09 28 69 66 20 28 73 79 | 6d 62 6f 6c 70 20 69 29 |.(if (sy|mbolp i)|
|00004d10| 0d 09 09 09 09 09 28 73 | 65 74 71 20 6d 61 73 6b |......(s|etq mask|
|00004d20| 20 28 2b 20 6d 61 73 6b | 20 28 67 65 74 20 69 20 | (+ mask| (get i |
|00004d30| 27 70 72 65 2d 64 65 63 | 72 65 6d 65 6e 74 2d 6d |'pre-dec|rement-m|
|00004d40| 61 73 6b 29 29 29 29 29 | 0d 09 09 09 28 72 65 74 |ask)))))|....(ret|
|00004d50| 75 72 6e 20 28 6c 69 73 | 74 2a 20 69 6e 73 74 72 |urn (lis|t* instr|
|00004d60| 75 63 74 69 6f 6e 20 6d | 61 73 6b 20 28 65 6e 63 |uction m|ask (enc|
|00004d70| 6f 64 65 64 2d 61 64 64 | 72 65 73 73 2d 64 61 74 |oded-add|ress-dat|
|00004d80| 61 20 65 61 29 29 29 29 | 29 29 29 20 0d 0d 28 64 |a ea))))|))) ..(d|
|00004d90| 65 66 75 6e 20 6c 6f 6e | 67 2d 77 6f 72 64 73 20 |efun lon|g-words |
|00004da0| 28 61 64 64 72 29 20 28 | 6d 75 6c 74 69 70 6c 65 |(addr) (|multiple|
|00004db0| 2d 76 61 6c 75 65 2d 6c | 69 73 74 20 28 66 6c 6f |-value-l|ist (flo|
|00004dc0| 6f 72 20 61 64 64 72 20 | 23 78 31 30 30 30 30 29 |or addr |#x10000)|
|00004dd0| 29 29 0d 0d 3b 0d 3b 09 | 65 6e 63 6f 64 65 2d 61 |))..;.;.|encode-a|
|00004de0| 64 64 72 65 73 73 0d 3b | 09 52 65 74 75 72 6e 73 |ddress.;|.Returns|
|00004df0| 20 61 20 6c 69 73 74 20 | 63 6f 6e 73 69 73 74 69 | a list |consisti|
|00004e00| 6e 67 20 6f 66 3a 0d 3b | 09 09 28 6d 6f 64 65 20 |ng of:.;|..(mode |
|00004e10| 72 65 67 20 64 61 74 61 | 31 20 64 61 74 61 32 20 |reg data|1 data2 |
|00004e20| 64 61 74 61 33 20 2e 2e | 2e 29 0d 3b 09 77 68 65 |data3 ..|.).;.whe|
|00004e30| 72 65 20 74 68 65 72 65 | 20 6d 61 79 20 62 65 20 |re there| may be |
|00004e40| 5b 30 2e 2e 6e 5d 20 64 | 61 74 61 20 77 6f 72 64 |[0..n] d|ata word|
|00004e50| 73 20 28 31 36 2d 62 69 | 74 20 71 75 61 6e 74 69 |s (16-bi|t quanti|
|00004e60| 74 69 65 73 29 0d 3b 0d | 28 64 65 66 75 6e 20 65 |ties).;.|(defun e|
|00004e70| 6e 63 6f 64 65 2d 61 64 | 64 72 65 73 73 20 28 61 |ncode-ad|dress (a|
|00004e80| 64 64 72 20 26 6f 70 74 | 69 6f 6e 61 6c 20 28 73 |ddr &opt|ional (s|
|00004e90| 69 7a 65 20 27 6c 6f 6e | 67 29 20 26 61 75 78 20 |ize 'lon|g) &aux |
|00004ea0| 72 65 74 76 61 6c 29 20 | 0d 09 28 63 6f 6e 64 0d |retval) |..(cond.|
|00004eb0| 09 09 28 28 61 6e 64 20 | 28 63 6f 6e 73 70 20 61 |..((and |(consp a|
|00004ec0| 64 64 72 29 20 28 65 71 | 20 28 63 61 72 20 61 64 |ddr) (eq| (car ad|
|00004ed0| 64 72 29 20 27 66 75 6e | 63 74 69 6f 6e 29 29 0d |dr) 'fun|ction)).|
|00004ee0| 09 09 20 28 6c 65 74 20 | 28 28 65 78 65 63 20 28 |.. (let |((exec (|
|00004ef0| 65 78 65 63 2d 61 64 64 | 72 65 73 73 20 28 63 61 |exec-add|ress (ca|
|00004f00| 64 72 20 61 64 64 72 29 | 29 29 29 0d 09 09 09 28 |dr addr)|)))....(|
|00004f10| 61 64 64 2d 72 65 66 65 | 72 65 6e 63 65 20 61 64 |add-refe|rence ad|
|00004f20| 64 72 29 0d 09 09 09 28 | 73 65 74 71 20 72 65 74 |dr)....(|setq ret|
|00004f30| 76 61 6c 20 28 6c 69 73 | 74 2a 20 37 20 34 20 28 |val (lis|t* 7 4 (|
|00004f40| 6c 6f 6e 67 2d 77 6f 72 | 64 73 20 65 78 65 63 29 |long-wor|ds exec)|
|00004f50| 29 29 29 29 0d 0d 09 09 | 28 28 61 6e 64 20 28 63 |))))....|((and (c|
|00004f60| 6f 6e 73 70 20 61 64 64 | 72 29 20 28 65 71 20 28 |onsp add|r) (eq (|
|00004f70| 63 61 72 20 61 64 64 72 | 29 20 27 71 75 6f 74 65 |car addr|) 'quote|
|00004f80| 29 29 0d 09 09 20 28 6c | 65 74 20 28 28 65 78 65 |))... (l|et ((exe|
|00004f90| 63 20 28 61 64 64 72 65 | 73 73 20 28 63 61 64 72 |c (addre|ss (cadr|
|00004fa0| 20 61 64 64 72 29 29 29 | 29 0d 09 09 09 28 61 64 | addr)))|)....(ad|
|00004fb0| 64 2d 72 65 66 65 72 65 | 6e 63 65 20 61 64 64 72 |d-refere|nce addr|
|00004fc0| 29 0d 09 09 09 28 73 65 | 74 71 20 72 65 74 76 61 |)....(se|tq retva|
|00004fd0| 6c 20 28 6c 69 73 74 2a | 20 37 20 34 20 28 6c 6f |l (list*| 7 4 (lo|
|00004fe0| 6e 67 2d 77 6f 72 64 73 | 20 65 78 65 63 29 29 29 |ng-words| exec)))|
|00004ff0| 29 29 0d 0d 09 09 28 28 | 61 6e 64 20 28 63 6f 6e |))....((|and (con|
|00005000| 73 70 20 61 64 64 72 29 | 20 28 65 71 20 28 63 61 |sp addr)| (eq (ca|
|00005010| 72 20 61 64 64 72 29 20 | 27 73 79 6d 62 6f 6c 2d |r addr) |'symbol-|
|00005020| 66 75 6e 63 74 69 6f 6e | 29 29 0d 09 09 20 28 6c |function|))... (l|
|00005030| 65 74 20 28 28 66 75 6e | 63 20 28 61 64 64 72 65 |et ((fun|c (addre|
|00005040| 73 73 20 28 73 79 6d 62 | 6f 6c 2d 66 75 6e 63 74 |ss (symb|ol-funct|
|00005050| 69 6f 6e 20 28 63 61 64 | 72 20 61 64 64 72 29 29 |ion (cad|r addr))|
|00005060| 29 29 29 0d 09 09 09 28 | 61 64 64 2d 72 65 66 65 |)))....(|add-refe|
|00005070| 72 65 6e 63 65 20 61 64 | 64 72 29 0d 09 09 09 28 |rence ad|dr)....(|
|00005080| 73 65 74 71 20 72 65 74 | 76 61 6c 20 28 6c 69 73 |setq ret|val (lis|
|00005090| 74 2a 20 37 20 34 20 28 | 6c 6f 6e 67 2d 77 6f 72 |t* 7 4 (|long-wor|
|000050a0| 64 73 20 66 75 6e 63 29 | 29 29 29 29 0d 0d 09 09 |ds func)|))))....|
|000050b0| 28 28 73 79 6d 62 6f 6c | 70 20 61 64 64 72 29 0d |((symbol|p addr).|
|000050c0| 09 09 20 28 63 6f 6e 64 | 0d 09 09 09 28 28 6d 65 |.. (cond|....((me|
|000050d0| 6d 62 65 72 20 61 64 64 | 72 20 64 2d 72 65 67 69 |mber add|r d-regi|
|000050e0| 73 74 65 72 73 29 20 0d | 09 09 09 09 28 73 65 74 |sters) .|....(set|
|000050f0| 71 20 72 65 74 76 61 6c | 20 28 6c 69 73 74 20 30 |q retval| (list 0|
|00005100| 20 28 73 79 6d 62 6f 6c | 2d 76 61 6c 75 65 20 61 | (symbol|-value a|
|00005110| 64 64 72 29 29 29 29 0d | 09 09 09 28 28 6d 65 6d |ddr)))).|...((mem|
|00005120| 62 65 72 20 61 64 64 72 | 20 61 2d 72 65 67 69 73 |ber addr| a-regis|
|00005130| 74 65 72 73 29 20 0d 09 | 09 09 09 28 73 65 74 71 |ters) ..|...(setq|
|00005140| 20 72 65 74 76 61 6c 20 | 28 6c 69 73 74 20 31 20 | retval |(list 1 |
|00005150| 28 73 79 6d 62 6f 6c 2d | 76 61 6c 75 65 20 61 64 |(symbol-|value ad|
|00005160| 64 72 29 29 29 29 0d 09 | 09 09 28 74 20 0d 09 09 |dr))))..|..(t ...|
|00005170| 09 09 28 61 64 64 2d 72 | 65 66 65 72 65 6e 63 65 |..(add-r|eference|
|00005180| 20 60 28 73 79 6d 62 6f | 6c 2d 76 61 6c 75 65 20 | `(symbo|l-value |
|00005190| 2c 61 64 64 72 29 29 0d | 09 09 09 09 28 73 65 74 |,addr)).|....(set|
|000051a0| 71 20 61 64 64 72 20 28 | 73 79 6d 62 6f 6c 2d 76 |q addr (|symbol-v|
|000051b0| 61 6c 75 65 20 61 64 64 | 72 29 29 0d 09 09 09 09 |alue add|r)).....|
|000051c0| 28 69 66 20 28 65 71 20 | 73 69 7a 65 20 27 6c 6f |(if (eq |size 'lo|
|000051d0| 6e 67 29 0d 09 09 09 09 | 09 28 73 65 74 71 20 72 |ng).....|.(setq r|
|000051e0| 65 74 76 61 6c 20 28 6c | 69 73 74 2a 20 37 20 34 |etval (l|ist* 7 4|
|000051f0| 20 28 6c 6f 6e 67 2d 77 | 6f 72 64 73 20 61 64 64 | (long-w|ords add|
|00005200| 72 29 29 29 0d 09 09 09 | 09 09 28 73 65 74 71 20 |r)))....|..(setq |
|00005210| 72 65 74 76 61 6c 20 28 | 6c 69 73 74 20 37 20 34 |retval (|list 7 4|
|00005220| 20 28 6d 6f 64 20 61 64 | 64 72 20 23 78 31 30 30 | (mod ad|dr #x100|
|00005230| 30 30 29 29 29 29 29 29 | 29 0d 0d 09 09 28 28 63 |00))))))|)....((c|
|00005240| 6f 6e 73 70 20 61 64 64 | 72 29 0d 09 09 20 28 73 |onsp add|r)... (s|
|00005250| 65 74 71 20 72 65 74 76 | 61 6c 20 0d 09 09 09 28 |etq retv|al ....(|
|00005260| 63 6f 6e 64 0d 09 09 09 | 09 28 28 6d 65 6d 62 65 |cond....|.((membe|
|00005270| 72 20 28 63 61 72 20 61 | 64 64 72 29 20 61 2d 72 |r (car a|ddr) a-r|
|00005280| 65 67 69 73 74 65 72 73 | 29 20 0d 09 09 09 09 20 |egisters|) ..... |
|00005290| 28 69 66 20 28 61 6e 64 | 20 28 63 64 72 20 61 64 |(if (and| (cdr ad|
|000052a0| 64 72 29 20 28 2f 3d 20 | 28 63 61 64 72 20 61 64 |dr) (/= |(cadr ad|
|000052b0| 64 72 29 20 30 29 29 0d | 09 09 09 09 20 09 28 6c |dr) 0)).|.... .(l|
|000052c0| 69 73 74 2a 20 35 20 28 | 73 79 6d 62 6f 6c 2d 76 |ist* 5 (|symbol-v|
|000052d0| 61 6c 75 65 20 28 63 61 | 72 20 61 64 64 72 29 29 |alue (ca|r addr))|
|000052e0| 20 28 63 64 72 20 61 64 | 64 72 29 29 0d 09 09 09 | (cdr ad|dr))....|
|000052f0| 09 09 28 6c 69 73 74 20 | 32 20 28 73 79 6d 62 6f |..(list |2 (symbo|
|00005300| 6c 2d 76 61 6c 75 65 20 | 28 63 61 72 20 61 64 64 |l-value |(car add|
|00005310| 72 29 29 29 29 29 0d 09 | 09 09 09 28 28 6d 65 6d |r)))))..|...((mem|
|00005320| 62 65 72 20 28 63 61 72 | 20 61 64 64 72 29 20 61 |ber (car| addr) a|
|00005330| 2d 69 6e 63 2d 72 65 67 | 69 73 74 65 72 73 29 20 |-inc-reg|isters) |
|00005340| 0d 09 09 09 09 20 28 6c | 69 73 74 20 33 20 28 73 |..... (l|ist 3 (s|
|00005350| 79 6d 62 6f 6c 2d 76 61 | 6c 75 65 20 28 63 61 72 |ymbol-va|lue (car|
|00005360| 20 61 64 64 72 29 29 29 | 29 0d 09 09 09 09 28 28 | addr)))|).....((|
|00005370| 6d 65 6d 62 65 72 20 28 | 63 61 72 20 61 64 64 72 |member (|car addr|
|00005380| 29 20 61 2d 64 65 63 2d | 72 65 67 69 73 74 65 72 |) a-dec-|register|
|00005390| 73 29 20 0d 09 09 09 09 | 20 28 6c 69 73 74 20 34 |s) .....| (list 4|
|000053a0| 20 28 73 79 6d 62 6f 6c | 2d 76 61 6c 75 65 20 28 | (symbol|-value (|
|000053b0| 63 61 72 20 61 64 64 72 | 29 29 29 29 0d 09 09 09 |car addr|))))....|
|000053c0| 09 28 28 61 6e 64 20 28 | 73 79 6d 62 6f 6c 70 20 |.((and (|symbolp |
|000053d0| 28 63 61 72 20 61 64 64 | 72 29 29 20 28 6e 75 6c |(car add|r)) (nul|
|000053e0| 6c 20 28 63 64 72 20 61 | 64 64 72 29 29 29 0d 09 |l (cdr a|ddr)))..|
|000053f0| 09 09 09 20 28 61 64 64 | 2d 72 65 66 65 72 65 6e |... (add|-referen|
|00005400| 63 65 20 60 28 73 79 6d | 62 6f 6c 2d 76 61 6c 75 |ce `(sym|bol-valu|
|00005410| 65 20 2c 28 63 61 72 20 | 61 64 64 72 29 29 29 0d |e ,(car |addr))).|
|00005420| 09 09 09 09 20 28 6c 69 | 73 74 2a 20 37 20 31 20 |.... (li|st* 7 1 |
|00005430| 28 6c 6f 6e 67 2d 77 6f | 72 64 73 20 28 73 79 6d |(long-wo|rds (sym|
|00005440| 62 6f 6c 2d 76 61 6c 75 | 65 20 28 63 61 72 20 61 |bol-valu|e (car a|
|00005450| 64 64 72 29 29 29 29 29 | 0d 09 09 09 09 28 28 61 |ddr)))))|.....((a|
|00005460| 6e 64 20 28 69 6e 74 65 | 67 65 72 70 20 28 63 61 |nd (inte|gerp (ca|
|00005470| 72 20 61 64 64 72 29 29 | 20 28 6e 75 6c 6c 20 28 |r addr))| (null (|
|00005480| 63 64 72 20 61 64 64 72 | 29 29 29 0d 09 09 09 09 |cdr addr|))).....|
|00005490| 20 28 6c 69 73 74 2a 20 | 37 20 31 20 28 6c 6f 6e | (list* |7 1 (lon|
|000054a0| 67 2d 77 6f 72 64 73 20 | 28 63 61 72 20 61 64 64 |g-words |(car add|
|000054b0| 72 29 29 29 29 0d 09 09 | 09 09 28 74 20 28 65 72 |r))))...|..(t (er|
|000054c0| 72 6f 72 20 22 55 6e 6b | 6e 6f 77 6e 20 61 64 64 |ror "Unk|nown add|
|000054d0| 72 65 73 73 20 65 78 70 | 72 65 73 73 69 6f 6e 3a |ress exp|ression:|
|000054e0| 20 7e 41 22 20 61 64 64 | 72 29 29 29 29 29 0d 0d | ~A" add|r)))))..|
|000054f0| 09 09 28 28 69 6e 74 65 | 67 65 72 70 20 61 64 64 |..((inte|gerp add|
|00005500| 72 29 0d 09 09 20 28 69 | 66 20 28 65 71 20 73 69 |r)... (i|f (eq si|
|00005510| 7a 65 20 27 6c 6f 6e 67 | 29 0d 09 09 09 28 73 65 |ze 'long|)....(se|
|00005520| 74 71 20 72 65 74 76 61 | 6c 20 28 6c 69 73 74 2a |tq retva|l (list*|
|00005530| 20 37 20 34 20 28 6c 6f | 6e 67 2d 77 6f 72 64 73 | 7 4 (lo|ng-words|
|00005540| 20 61 64 64 72 29 29 29 | 0d 09 09 09 28 73 65 74 | addr)))|....(set|
|00005550| 71 20 72 65 74 76 61 6c | 20 28 6c 69 73 74 20 37 |q retval| (list 7|
|00005560| 20 34 20 28 6d 6f 64 20 | 61 64 64 72 20 23 78 31 | 4 (mod |addr #x1|
|00005570| 30 30 30 30 29 29 29 29 | 29 0d 09 09 09 0d 09 09 |0000))))|).......|
|00005580| 28 74 20 28 65 72 72 6f | 72 20 22 55 6e 6b 6e 6f |(t (erro|r "Unkno|
|00005590| 77 6e 20 61 64 64 72 65 | 73 73 20 65 78 70 72 65 |wn addre|ss expre|
|000055a0| 73 73 69 6f 6e 3a 20 7e | 41 22 20 61 64 64 72 29 |ssion: ~|A" addr)|
|000055b0| 29 29 0d 0d 09 28 69 66 | 20 28 3e 20 28 6c 65 6e |))...(if| (> (len|
|000055c0| 67 74 68 20 72 65 74 76 | 61 6c 29 20 32 29 0d 09 |gth retv|al) 2)..|
|000055d0| 09 28 69 6e 63 66 20 2a | 61 73 73 65 6d 62 6c 65 |.(incf *|assemble|
|000055e0| 72 2d 6c 6f 63 61 6c 2d | 61 64 64 72 65 73 73 2a |r-local-|address*|
|000055f0| 20 28 2a 20 32 20 28 6c | 65 6e 67 74 68 20 72 65 | (* 2 (l|ength re|
|00005600| 74 76 61 6c 29 29 29 29 | 0d 09 28 72 65 74 75 72 |tval))))|..(retur|
|00005610| 6e 20 72 65 74 76 61 6c | 29 29 0d 0d 3b 3b 0d 3b |n retval|))..;;.;|
|00005620| 3b 09 65 6e 63 6f 64 65 | 64 2d 61 64 64 72 65 73 |;.encode|d-addres|
|00005630| 73 2d 6d 6f 64 65 0d 3b | 3b 09 52 65 74 75 72 6e |s-mode.;|;.Return|
|00005640| 73 20 74 68 65 20 6d 6f | 64 65 20 28 69 6e 74 65 |s the mo|de (inte|
|00005650| 67 65 72 29 20 6f 66 20 | 74 68 65 20 70 61 73 73 |ger) of |the pass|
|00005660| 65 64 20 61 64 64 72 65 | 73 73 20 73 74 72 75 63 |ed addre|ss struc|
|00005670| 74 75 72 65 2e 0d 3b 3b | 0d 28 64 65 66 75 6e 20 |ture..;;|.(defun |
|00005680| 65 6e 63 6f 64 65 64 2d | 61 64 64 72 65 73 73 2d |encoded-|address-|
|00005690| 6d 6f 64 65 20 28 61 64 | 64 72 29 0d 09 28 63 61 |mode (ad|dr)..(ca|
|000056a0| 72 20 61 64 64 72 29 29 | 0d 0d 28 64 65 66 75 6e |r addr))|..(defun|
|000056b0| 20 65 6e 63 6f 64 65 64 | 2d 61 64 64 72 65 73 73 | encoded|-address|
|000056c0| 2d 72 65 67 20 28 61 64 | 64 72 29 0d 09 28 63 61 |-reg (ad|dr)..(ca|
|000056d0| 64 72 20 61 64 64 72 29 | 29 0d 0d 28 64 65 66 75 |dr addr)|)..(defu|
|000056e0| 6e 20 65 6e 63 6f 64 65 | 64 2d 61 64 64 72 65 73 |n encode|d-addres|
|000056f0| 73 2d 64 61 74 61 20 28 | 61 64 64 72 29 0d 09 28 |s-data (|addr)..(|
|00005700| 63 64 64 72 20 61 64 64 | 72 29 29 0d 09 0d 28 64 |cddr add|r))...(d|
|00005710| 65 66 75 6e 20 61 73 73 | 65 6d 62 6c 65 20 28 61 |efun ass|emble (a|
|00005720| 73 73 65 6d 62 6c 65 72 | 2d 69 6e 73 74 72 75 63 |ssembler|-instruc|
|00005730| 74 69 6f 6e 73 20 72 65 | 66 65 72 65 6e 63 65 73 |tions re|ferences|
|00005740| 20 26 6f 70 74 69 6f 6e | 61 6c 20 65 6e 76 69 72 | &option|al envir|
|00005750| 6f 6e 6d 65 6e 74 29 0d | 20 20 28 6c 65 74 2a 0d |onment).| (let*.|
|00005760| 09 28 28 6c 61 62 65 6c | 2d 74 61 62 6c 65 20 28 |.((label|-table (|
|00005770| 6d 61 6b 65 2d 68 61 73 | 68 2d 74 61 62 6c 65 20 |make-has|h-table |
|00005780| 3a 74 65 73 74 20 23 27 | 65 71 6c 29 29 0d 09 20 |:test #'|eql)).. |
|00005790| 20 28 6e 65 77 6c 69 73 | 74 20 6e 69 6c 29 0d 09 | (newlis|t nil)..|
|000057a0| 20 20 28 63 6f 64 65 6c | 69 73 74 20 6e 69 6c 29 | (codel|ist nil)|
|000057b0| 0d 09 20 20 28 2a 61 73 | 73 65 6d 62 6c 65 72 2d |.. (*as|sembler-|
|000057c0| 61 64 64 72 65 73 73 2a | 20 30 29 0d 09 20 20 28 |address*| 0).. (|
|000057d0| 2a 61 73 73 65 6d 62 6c | 65 72 2d 6c 6f 63 61 6c |*assembl|er-local|
|000057e0| 2d 61 64 64 72 65 73 73 | 2a 20 30 29 0d 09 20 20 |-address|* 0).. |
|000057f0| 28 2a 61 73 73 65 6d 62 | 6c 65 72 2d 72 65 66 65 |(*assemb|ler-refe|
|00005800| 72 65 6e 63 65 73 2a 20 | 6e 69 6c 29 0d 09 20 20 |rences* |nil).. |
|00005810| 6f 70 65 72 61 74 6f 72 | 29 0d 0d 09 28 64 6f 20 |operator|)...(do |
|00005820| 28 28 6e 20 61 73 73 65 | 6d 62 6c 65 72 2d 69 6e |((n asse|mbler-in|
|00005830| 73 74 72 75 63 74 69 6f | 6e 73 20 28 63 64 72 20 |structio|ns (cdr |
|00005840| 6e 29 29 0d 09 09 20 73 | 74 61 74 65 6d 65 6e 74 |n))... s|tatement|
|00005850| 29 0d 09 09 28 28 6e 75 | 6c 6c 20 6e 29 29 0d 09 |)...((nu|ll n))..|
|00005860| 09 28 73 65 74 71 20 73 | 74 61 74 65 6d 65 6e 74 |.(setq s|tatement|
|00005870| 20 28 63 61 72 20 6e 29 | 29 0d 09 09 28 63 6f 6e | (car n)|)...(con|
|00005880| 64 0d 09 09 09 3b 3b 20 | 69 66 20 69 74 20 69 73 |d....;; |if it is|
|00005890| 20 61 20 6c 61 62 65 6c | 2c 20 61 64 64 20 69 74 | a label|, add it|
|000058a0| 20 74 6f 20 74 68 65 20 | 68 61 73 68 20 74 61 62 | to the |hash tab|
|000058b0| 6c 65 0d 09 09 09 28 28 | 73 79 6d 62 6f 6c 70 20 |le....((|symbolp |
|000058c0| 73 74 61 74 65 6d 65 6e | 74 29 20 0d 09 09 09 20 |statemen|t) .... |
|000058d0| 28 73 65 74 66 20 28 67 | 65 74 68 61 73 68 20 73 |(setf (g|ethash s|
|000058e0| 74 61 74 65 6d 65 6e 74 | 20 6c 61 62 65 6c 2d 74 |tatement| label-t|
|000058f0| 61 62 6c 65 29 20 2a 61 | 73 73 65 6d 62 6c 65 72 |able) *a|ssembler|
|00005900| 2d 61 64 64 72 65 73 73 | 2a 29 29 0d 09 09 09 28 |-address|*))....(|
|00005910| 28 63 6f 6e 73 70 20 73 | 74 61 74 65 6d 65 6e 74 |(consp s|tatement|
|00005920| 29 0d 09 09 09 20 28 69 | 66 20 28 69 6e 74 65 67 |).... (i|f (integ|
|00005930| 65 72 70 20 28 63 61 72 | 20 73 74 61 74 65 6d 65 |erp (car| stateme|
|00005940| 6e 74 29 29 20 09 3b 3b | 20 73 6b 69 70 20 61 64 |nt)) .;;| skip ad|
|00005950| 64 72 65 73 73 20 69 66 | 20 74 68 65 72 65 20 69 |dress if| there i|
|00005960| 73 20 6f 6e 65 0d 09 09 | 09 20 09 28 73 65 74 71 |s one...|. .(setq|
|00005970| 20 73 74 61 74 65 6d 65 | 6e 74 20 28 63 64 72 20 | stateme|nt (cdr |
|00005980| 73 74 61 74 65 6d 65 6e | 74 29 29 29 0d 09 09 09 |statemen|t)))....|
|00005990| 20 0d 09 09 09 20 3b 3b | 20 6d 61 6b 65 20 73 75 | .... ;;| make su|
|000059a0| 72 65 20 74 68 65 72 65 | 20 69 73 20 61 20 6d 61 |re there| is a ma|
|000059b0| 63 72 6f 20 64 65 66 69 | 6e 69 74 69 6f 6e 0d 09 |cro defi|nition..|
|000059c0| 09 09 20 28 73 65 74 71 | 20 6f 70 65 72 61 74 6f |.. (setq| operato|
|000059d0| 72 20 28 63 61 72 20 73 | 74 61 74 65 6d 65 6e 74 |r (car s|tatement|
|000059e0| 29 29 0d 09 09 09 20 28 | 75 6e 6c 65 73 73 20 28 |)).... (|unless (|
|000059f0| 73 79 6d 62 6f 6c 70 20 | 6f 70 65 72 61 74 6f 72 |symbolp |operator|
|00005a00| 29 20 0d 09 09 09 20 09 | 28 65 72 72 6f 72 20 22 |) .... .|(error "|
|00005a10| 49 6e 76 61 6c 69 64 20 | 69 6e 73 74 72 75 63 74 |Invalid |instruct|
|00005a20| 69 6f 6e 3a 20 7e 41 22 | 20 6f 70 65 72 61 74 6f |ion: ~A"| operato|
|00005a30| 72 29 29 0d 09 09 09 20 | 28 75 6e 6c 65 73 73 20 |r)).... |(unless |
|00005a40| 28 6d 61 63 72 6f 2d 66 | 75 6e 63 74 69 6f 6e 20 |(macro-f|unction |
|00005a50| 6f 70 65 72 61 74 6f 72 | 29 0d 09 09 09 20 09 28 |operator|).... .(|
|00005a60| 65 72 72 6f 72 20 22 4e | 6f 20 64 65 66 69 6e 69 |error "N|o defini|
|00005a70| 74 69 6f 6e 20 66 6f 72 | 20 69 6e 73 74 72 75 63 |tion for| instruc|
|00005a80| 74 69 6f 6e 3a 20 7e 41 | 22 20 73 74 61 74 65 6d |tion: ~A|" statem|
|00005a90| 65 6e 74 29 29 0d 0d 09 | 09 09 20 3b 3b 20 65 78 |ent))...|.. ;; ex|
|00005aa0| 70 61 6e 64 20 74 68 65 | 20 6d 61 63 72 6f 20 6f |pand the| macro o|
|00005ab0| 6e 65 20 74 69 6d 65 0d | 09 09 09 20 28 73 65 74 |ne time.|... (set|
|00005ac0| 71 20 2a 61 73 73 65 6d | 62 6c 65 72 2d 6c 6f 63 |q *assem|bler-loc|
|00005ad0| 61 6c 2d 61 64 64 72 65 | 73 73 2a 20 32 29 09 3b |al-addre|ss* 2).;|
|00005ae0| 3b 20 72 65 73 65 74 20 | 74 68 69 73 20 65 61 63 |; reset |this eac|
|00005af0| 68 20 69 6e 73 74 72 75 | 63 74 69 6f 6e 0d 09 09 |h instru|ction...|
|00005b00| 09 20 28 73 65 74 71 20 | 73 74 61 74 65 6d 65 6e |. (setq |statemen|
|00005b10| 74 20 28 6d 61 63 72 6f | 65 78 70 61 6e 64 2d 31 |t (macro|expand-1|
|00005b20| 20 73 74 61 74 65 6d 65 | 6e 74 29 29 0d 09 09 09 | stateme|nt))....|
|00005b30| 20 0d 09 09 09 20 3b 3b | 20 63 68 65 63 6b 20 66 | .... ;;| check f|
|00005b40| 6f 72 20 6d 75 6c 74 69 | 70 6c 65 20 73 74 61 74 |or multi|ple stat|
|00005b50| 65 6d 65 6e 74 20 72 65 | 73 75 6c 74 20 28 61 73 |ement re|sult (as|
|00005b60| 73 65 6d 62 6c 65 72 20 | 6d 61 63 72 6f 20 65 78 |sembler |macro ex|
|00005b70| 70 61 6e 73 69 6f 6e 29 | 0d 09 09 09 20 28 69 66 |pansion)|.... (if|
|00005b80| 20 28 61 6e 64 20 28 63 | 6f 6e 73 70 20 73 74 61 | (and (c|onsp sta|
|00005b90| 74 65 6d 65 6e 74 29 20 | 28 6e 6f 74 20 28 69 6e |tement) |(not (in|
|00005ba0| 74 65 67 65 72 70 20 28 | 63 61 72 20 73 74 61 74 |tegerp (|car stat|
|00005bb0| 65 6d 65 6e 74 29 29 29 | 29 0d 09 09 09 20 09 3b |ement)))|).... .;|
|00005bc0| 3b 20 6a 75 73 74 20 73 | 70 6c 69 63 65 20 69 6e |; just s|plice in|
|00005bd0| 20 74 68 65 20 6e 65 77 | 20 69 6e 73 74 72 75 63 | the new| instruc|
|00005be0| 74 69 6f 6e 73 20 61 6e | 64 20 63 6f 6e 74 69 6e |tions an|d contin|
|00005bf0| 75 65 0d 09 09 09 09 28 | 73 65 74 71 20 6e 20 28 |ue.....(|setq n (|
|00005c00| 61 70 70 65 6e 64 20 28 | 6c 69 73 74 20 6e 69 6c |append (|list nil|
|00005c10| 29 20 73 74 61 74 65 6d | 65 6e 74 20 28 63 64 72 |) statem|ent (cdr|
|00005c20| 20 6e 29 29 29 0d 09 09 | 09 09 28 69 66 20 28 63 | n)))...|..(if (c|
|00005c30| 6f 6e 73 70 20 73 74 61 | 74 65 6d 65 6e 74 29 0d |onsp sta|tement).|
|00005c40| 09 09 09 09 09 3b 3b 20 | 54 68 69 73 20 61 64 64 |.....;; |This add|
|00005c50| 72 65 73 73 20 69 73 20 | 6f 6e 6c 79 20 63 6f 72 |ress is |only cor|
|00005c60| 72 65 63 74 20 62 65 63 | 61 75 73 65 20 77 65 20 |rect bec|ause we |
|00005c70| 61 72 65 20 72 65 71 75 | 69 72 69 6e 67 0d 09 09 |are requ|iring...|
|00005c80| 09 09 09 3b 3b 20 61 6c | 6c 20 62 72 61 6e 63 68 |...;; al|l branch|
|00005c90| 20 64 65 73 74 69 6e 61 | 74 69 6f 6e 73 20 74 6f | destina|tions to|
|00005ca0| 20 62 65 20 31 36 2d 62 | 69 74 20 6f 66 66 73 65 | be 16-b|it offse|
|00005cb0| 74 73 2e 20 0d 09 09 09 | 09 09 3b 3b 20 54 68 69 |ts. ....|..;; Thi|
|00005cc0| 73 20 61 76 6f 69 64 73 | 20 68 61 76 69 6e 67 20 |s avoids| having |
|00005cd0| 74 6f 20 63 61 6c 63 75 | 6c 61 74 65 20 74 68 65 |to calcu|late the|
|00005ce0| 20 73 69 7a 65 73 20 68 | 65 72 65 2e 0d 09 09 09 | sizes h|ere.....|
|00005cf0| 09 09 3b 3b 20 69 2e 65 | 2e 20 65 61 63 68 20 73 |..;; i.e|. each s|
|00005d00| 79 6d 62 6f 6c 20 62 65 | 63 6f 6d 65 73 20 6f 6e |ymbol be|comes on|
|00005d10| 65 20 31 36 2d 62 69 74 | 20 64 69 73 70 6c 61 63 |e 16-bit| displac|
|00005d20| 65 6d 65 6e 74 20 77 6f | 72 64 2e 0d 09 09 09 09 |ement wo|rd......|
|00005d30| 09 28 70 72 6f 67 6e 0d | 09 09 09 09 09 09 28 69 |.(progn.|......(i|
|00005d40| 6e 63 66 20 2a 61 73 73 | 65 6d 62 6c 65 72 2d 61 |ncf *ass|embler-a|
|00005d50| 64 64 72 65 73 73 2a 20 | 28 2a 20 28 6c 65 6e 67 |ddress* |(* (leng|
|00005d60| 74 68 20 73 74 61 74 65 | 6d 65 6e 74 29 20 32 29 |th state|ment) 2)|
|00005d70| 29 0d 09 09 09 09 09 09 | 28 70 75 73 68 20 73 74 |).......|(push st|
|00005d80| 61 74 65 6d 65 6e 74 20 | 6e 65 77 6c 69 73 74 29 |atement |newlist)|
|00005d90| 29 29 29 29 0d 09 09 09 | 0d 09 09 09 3b 3b 20 65 |))))....|....;; e|
|00005da0| 72 72 6f 72 20 69 66 20 | 6e 6f 74 20 61 20 73 79 |rror if |not a sy|
|00005db0| 6d 62 6f 6c 20 6f 72 20 | 61 20 6c 69 73 74 0d 09 |mbol or |a list..|
|00005dc0| 09 09 28 74 20 28 65 72 | 72 6f 72 20 22 49 6e 76 |..(t (er|ror "Inv|
|00005dd0| 61 6c 69 64 20 6c 61 62 | 65 6c 20 65 6e 63 6f 75 |alid lab|el encou|
|00005de0| 6e 74 65 72 65 64 3a 20 | 7e 41 22 20 73 74 61 74 |ntered: |~A" stat|
|00005df0| 65 6d 65 6e 74 29 29 29 | 29 0d 09 09 09 0d 09 3b |ement)))|)......;|
|00005e00| 3b 20 4e 6f 77 20 67 6f | 20 74 68 72 6f 75 67 68 |; Now go| through|
|00005e10| 20 61 6e 64 20 61 70 70 | 65 6e 64 20 61 6c 6c 20 | and app|end all |
|00005e20| 74 68 65 20 73 75 62 6c | 69 73 74 73 20 74 6f 67 |the subl|ists tog|
|00005e30| 65 74 68 65 72 2c 0d 09 | 3b 3b 20 72 65 73 6f 6c |ether,..|;; resol|
|00005e40| 76 69 6e 67 20 62 72 61 | 6e 63 68 20 61 64 64 72 |ving bra|nch addr|
|00005e50| 65 73 73 65 73 20 61 73 | 20 77 65 20 67 6f 2e 0d |esses as| we go..|
|00005e60| 09 3b 3b 20 57 65 20 6f | 6e 6c 79 20 63 75 72 72 |.;; We o|nly curr|
|00005e70| 65 6e 74 6c 79 20 73 75 | 70 70 6f 72 74 20 31 36 |ently su|pport 16|
|00005e80| 2d 62 69 74 20 64 69 73 | 70 6c 61 63 65 6d 65 6e |-bit dis|placemen|
|00005e90| 74 73 20 69 6e 20 74 68 | 65 20 62 72 61 6e 63 68 |ts in th|e branch|
|00005ea0| 0d 09 3b 3b 20 69 6e 73 | 74 72 75 63 74 69 6f 6e |..;; ins|truction|
|00005eb0| 73 2e 0d 0d 09 28 73 65 | 74 71 20 6e 65 77 6c 69 |s....(se|tq newli|
|00005ec0| 73 74 20 28 72 65 76 65 | 72 73 65 20 6e 65 77 6c |st (reve|rse newl|
|00005ed0| 69 73 74 29 29 0d 09 28 | 73 65 74 71 20 2a 61 73 |ist))..(|setq *as|
|00005ee0| 73 65 6d 62 6c 65 72 2d | 61 64 64 72 65 73 73 2a |sembler-|address*|
|00005ef0| 20 30 29 0d 09 28 64 6f | 6c 69 73 74 20 28 73 74 | 0)..(do|list (st|
|00005f00| 61 74 65 6d 65 6e 74 20 | 6e 65 77 6c 69 73 74 29 |atement |newlist)|
|00005f10| 0d 09 09 0d 09 09 3b 3b | 20 63 68 65 63 6b 20 66 |......;;| check f|
|00005f20| 6f 72 20 62 72 61 6e 63 | 68 20 69 6e 73 74 72 75 |or branc|h instru|
|00005f30| 63 74 69 6f 6e 73 0d 09 | 09 28 73 65 74 71 20 6f |ctions..|.(setq o|
|00005f40| 70 65 72 61 74 6f 72 20 | 28 63 61 72 20 73 74 61 |perator |(car sta|
|00005f50| 74 65 6d 65 6e 74 29 29 | 0d 09 09 28 69 66 20 28 |tement))|...(if (|
|00005f60| 3d 20 28 74 72 75 6e 63 | 61 74 65 20 6f 70 65 72 |= (trunc|ate oper|
|00005f70| 61 74 6f 72 20 23 78 31 | 30 30 30 29 20 36 29 0d |ator #x1|000) 6).|
|00005f80| 09 09 09 28 69 66 20 28 | 61 6e 64 20 28 63 6f 6e |...(if (|and (con|
|00005f90| 73 70 20 28 63 64 72 20 | 73 74 61 74 65 6d 65 6e |sp (cdr |statemen|
|00005fa0| 74 29 29 0d 09 09 09 09 | 09 28 73 79 6d 62 6f 6c |t)).....|.(symbol|
|00005fb0| 70 20 28 63 61 64 72 20 | 73 74 61 74 65 6d 65 6e |p (cadr |statemen|
|00005fc0| 74 29 29 29 0d 09 09 09 | 09 28 6c 65 74 2a 20 28 |t)))....|.(let* (|
|00005fd0| 28 73 79 6d 20 28 63 61 | 64 72 20 73 74 61 74 65 |(sym (ca|dr state|
|00005fe0| 6d 65 6e 74 29 29 0d 09 | 09 09 09 09 09 28 76 61 |ment))..|.....(va|
|00005ff0| 6c 75 65 20 28 67 65 74 | 68 61 73 68 20 73 79 6d |lue (get|hash sym|
|00006000| 20 6c 61 62 65 6c 2d 74 | 61 62 6c 65 29 29 29 0d | label-t|able))).|
|00006010| 09 09 09 09 09 28 75 6e | 6c 65 73 73 20 76 61 6c |.....(un|less val|
|00006020| 75 65 20 0d 09 09 09 09 | 09 09 28 65 72 72 6f 72 |ue .....|..(error|
|00006030| 20 22 4c 61 62 65 6c 20 | 6e 6f 74 20 66 6f 75 6e | "Label |not foun|
|00006040| 64 3a 20 7e 41 22 20 73 | 79 6d 29 29 0d 09 09 09 |d: ~A" s|ym))....|
|00006050| 09 09 28 75 6e 6c 65 73 | 73 20 28 69 6e 74 65 67 |..(unles|s (integ|
|00006060| 65 72 70 20 76 61 6c 75 | 65 29 20 0d 09 09 09 09 |erp valu|e) .....|
|00006070| 09 09 28 65 72 72 6f 72 | 20 22 49 6e 76 61 6c 69 |..(error| "Invali|
|00006080| 64 20 6c 61 62 65 6c 20 | 66 6f 75 6e 64 2e 7e 25 |d label |found.~%|
|00006090| 7e 41 4c 61 62 65 6c 3a | 20 7e 41 20 56 61 6c 75 |~ALabel:| ~A Valu|
|000060a0| 65 3a 20 7e 41 22 20 73 | 79 6d 20 76 61 6c 75 65 |e: ~A" s|ym value|
|000060b0| 29 29 0d 09 09 09 09 09 | 28 73 65 74 66 20 28 63 |))......|(setf (c|
|000060c0| 61 64 72 20 73 74 61 74 | 65 6d 65 6e 74 29 20 28 |adr stat|ement) (|
|000060d0| 2d 20 76 61 6c 75 65 20 | 28 2b 20 2a 61 73 73 65 |- value |(+ *asse|
|000060e0| 6d 62 6c 65 72 2d 61 64 | 64 72 65 73 73 2a 20 32 |mbler-ad|dress* 2|
|000060f0| 29 29 29 29 29 29 0d 09 | 09 0d 09 09 28 69 6e 63 |))))))..|....(inc|
|00006100| 66 20 2a 61 73 73 65 6d | 62 6c 65 72 2d 61 64 64 |f *assem|bler-add|
|00006110| 72 65 73 73 2a 20 28 2a | 20 32 20 28 6c 65 6e 67 |ress* (*| 2 (leng|
|00006120| 74 68 20 73 74 61 74 65 | 6d 65 6e 74 29 29 29 0d |th state|ment))).|
|00006130| 09 09 28 64 6f 6c 69 73 | 74 20 28 6e 20 73 74 61 |..(dolis|t (n sta|
|00006140| 74 65 6d 65 6e 74 29 20 | 28 70 75 73 68 20 6e 20 |tement) |(push n |
|00006150| 63 6f 64 65 6c 69 73 74 | 29 29 29 0d 09 09 0d 09 |codelist|))).....|
|00006160| 28 25 62 75 69 6c 64 2d | 66 75 6e 63 74 69 6f 6e |(%build-|function|
|00006170| 20 28 72 65 76 65 72 73 | 65 20 63 6f 64 65 6c 69 | (revers|e codeli|
|00006180| 73 74 29 20 2a 61 73 73 | 65 6d 62 6c 65 72 2d 72 |st) *ass|embler-r|
|00006190| 65 66 65 72 65 6e 63 65 | 73 2a 20 65 6e 76 69 72 |eference|s* envir|
|000061a0| 6f 6e 6d 65 6e 74 29 29 | 29 0d 0d 28 64 65 66 75 |onment))|)..(defu|
|000061b0| 6e 20 61 64 64 2d 72 65 | 66 65 72 65 6e 63 65 20 |n add-re|ference |
|000061c0| 28 72 65 66 20 26 6f 70 | 74 69 6f 6e 61 6c 20 28 |(ref &op|tional (|
|000061d0| 6f 66 66 73 65 74 20 30 | 29 29 0d 09 28 70 75 73 |offset 0|))..(pus|
|000061e0| 68 20 0d 09 09 28 63 6f | 6e 73 20 72 65 66 20 28 |h ...(co|ns ref (|
|000061f0| 2b 20 2a 61 73 73 65 6d | 62 6c 65 72 2d 61 64 64 |+ *assem|bler-add|
|00006200| 72 65 73 73 2a 20 2a 61 | 73 73 65 6d 62 6c 65 72 |ress* *a|ssembler|
|00006210| 2d 6c 6f 63 61 6c 2d 61 | 64 64 72 65 73 73 2a 20 |-local-a|ddress* |
|00006220| 6f 66 66 73 65 74 29 29 | 20 0d 09 09 2a 61 73 73 |offset))| ...*ass|
|00006230| 65 6d 62 6c 65 72 2d 72 | 65 66 65 72 65 6e 63 65 |embler-r|eference|
|00006240| 73 2a 29 29 0d 0d 29 20 | 20 3b 3b 20 63 6c 6f 73 |s*))..) | ;; clos|
|00006250| 65 20 65 6e 63 6c 6f 73 | 69 6e 67 20 65 76 61 6c |e enclos|ing eval|
|00006260| 2d 77 68 65 6e 20 66 6f | 72 6d 0d 09 0d 3b 3b 09 |-when fo|rm...;;.|
|00006270| 61 64 64 20 64 65 66 61 | 73 6d 20 74 6f 20 74 68 |add defa|sm to th|
|00006280| 65 20 63 6f 6d 6d 6f 6e | 20 6c 69 73 70 20 70 61 |e common| lisp pa|
|00006290| 63 6b 61 67 65 0d 0d 28 | 65 76 61 6c 2d 77 68 65 |ckage..(|eval-whe|
|000062a0| 6e 20 28 3a 63 6f 6d 70 | 69 6c 65 2d 74 6f 70 6c |n (:comp|ile-topl|
|000062b0| 65 76 65 6c 20 3a 6c 6f | 61 64 2d 74 6f 70 6c 65 |evel :lo|ad-tople|
|000062c0| 76 65 6c 20 3a 65 78 65 | 63 75 74 65 29 0d 09 28 |vel :exe|cute)..(|
|000062d0| 69 6e 2d 70 61 63 6b 61 | 67 65 20 3a 63 6f 6d 6d |in-packa|ge :comm|
|000062e0| 6f 6e 2d 6c 69 73 70 29 | 0d 09 28 65 78 70 6f 72 |on-lisp)|..(expor|
|000062f0| 74 20 27 63 6f 6d 6d 6f | 6e 2d 6c 69 73 70 3a 3a |t 'commo|n-lisp::|
|00006300| 64 65 66 61 73 6d 29 29 | 0d 0d 28 65 76 61 6c 2d |defasm))|..(eval-|
|00006310| 77 68 65 6e 20 28 3a 63 | 6f 6d 70 69 6c 65 2d 74 |when (:c|ompile-t|
|00006320| 6f 70 6c 65 76 65 6c 20 | 3a 6c 6f 61 64 2d 74 6f |oplevel |:load-to|
|00006330| 70 6c 65 76 65 6c 20 3a | 65 78 65 63 75 74 65 29 |plevel :|execute)|
|00006340| 0d 28 64 65 66 6d 61 63 | 72 6f 20 64 65 66 61 73 |.(defmac|ro defas|
|00006350| 6d 20 28 6e 61 6d 65 20 | 6c 61 6d 62 64 61 2d 6c |m (name |lambda-l|
|00006360| 69 73 74 20 26 72 65 73 | 74 20 66 6f 72 6d 73 29 |ist &res|t forms)|
|00006370| 0d 3b 09 28 64 65 63 6c | 61 72 65 20 28 75 6e 75 |.;.(decl|are (unu|
|00006380| 73 65 64 20 6c 61 6d 62 | 64 61 2d 6c 69 73 74 29 |sed lamb|da-list)|
|00006390| 29 0d 09 28 6c 65 74 20 | 28 28 64 6f 63 2d 66 6f |)..(let |((doc-fo|
|000063a0| 72 6d 20 6e 69 6c 29 29 | 0d 09 09 28 69 66 20 28 |rm nil))|...(if (|
|000063b0| 61 6e 64 20 28 74 79 70 | 65 70 20 28 63 61 72 20 |and (typ|ep (car |
|000063c0| 66 6f 72 6d 73 29 20 27 | 73 74 72 69 6e 67 29 0d |forms) '|string).|
|000063d0| 09 09 09 09 28 63 64 72 | 20 66 6f 72 6d 73 29 29 |....(cdr| forms))|
|000063e0| 0d 09 09 09 28 70 72 6f | 67 6e 0d 09 09 09 09 28 |....(pro|gn.....(|
|000063f0| 73 65 74 71 20 64 6f 63 | 2d 66 6f 72 6d 20 0d 09 |setq doc|-form ..|
+--------+-------------------------+-------------------------+--------+--------+
Only 25.0 KB of data is shown above.